Priority File Manager
📁 public_html
Base Directory:
/home/ecedu/public_html
/home/ecedu/public_html/wp-content/plugins
/home/ecedu/public_html/wp-content
/home/ecedu
/var/www
/var/www/cgi-bin
/var/www/html
public_html
/
wp-includes
/
js
/
dist
/home/ecedu/public_html/wp-includes/js/dist
Name
Type
Size
Actions
📁
..
Folder
-
Delete
Rename
📄
a11y.js
File
8570
Delete
Rename
Edit
Download
📄
a11y.min.js
File
2358
Delete
Rename
Edit
Download
📄
annotations.js
File
23335
Delete
Rename
Edit
Download
📄
annotations.min.js
File
5521
Delete
Rename
Edit
Download
📄
api-fetch.js
File
23874
Delete
Rename
Edit
Download
📄
api-fetch.min.js
File
5838
Delete
Rename
Edit
Download
📄
autop.js
File
15982
Delete
Rename
Edit
Download
📄
autop.min.js
File
5614
Delete
Rename
Edit
Download
📄
blob.js
File
4622
Delete
Rename
Edit
Download
📄
blob.min.js
File
1108
Delete
Rename
Edit
Download
📄
block-directory.js
File
80526
Delete
Rename
Edit
Download
📄
block-directory.min.js
File
20734
Delete
Rename
Edit
Download
📄
block-editor.js
File
2724345
Delete
Rename
Edit
Download
📄
block-editor.min.js
File
865941
Delete
Rename
Edit
Download
📄
block-library.js
File
2232874
Delete
Rename
Edit
Download
📄
block-library.min.js
File
876704
Delete
Rename
Edit
Download
📄
block-serialization-default-parser.js
File
15228
Delete
Rename
Edit
Download
📄
block-serialization-default-parser.min.js
File
2400
Delete
Rename
Edit
Download
📄
blocks.js
File
567313
Delete
Rename
Edit
Download
📄
blocks.min.js
File
173562
Delete
Rename
Edit
Download
📄
commands.js
File
182724
Delete
Rename
Edit
Download
📄
commands.min.js
File
49429
Delete
Rename
Edit
Download
📄
components.js
File
2357667
Delete
Rename
Edit
Download
📄
components.min.js
File
719028
Delete
Rename
Edit
Download
📄
compose.js
File
200300
Delete
Rename
Edit
Download
📄
compose.min.js
File
36853
Delete
Rename
Edit
Download
📄
core-commands.js
File
24398
Delete
Rename
Edit
Download
📄
core-commands.min.js
File
9416
Delete
Rename
Edit
Download
📄
core-data.js
File
267493
Delete
Rename
Edit
Download
📄
core-data.min.js
File
65783
Delete
Rename
Edit
Download
📄
customize-widgets.js
File
97615
Delete
Rename
Edit
Download
📄
customize-widgets.min.js
File
34999
Delete
Rename
Edit
Download
📄
data-controls.js
File
7243
Delete
Rename
Edit
Download
📄
data-controls.min.js
File
1472
Delete
Rename
Edit
Download
📄
data.js
File
144947
Delete
Rename
Edit
Download
📄
data.min.js
File
25596
Delete
Rename
Edit
Download
📄
date.js
File
817573
Delete
Rename
Edit
Download
📄
date.min.js
File
783424
Delete
Rename
Edit
Download
📄
deprecated.js
File
4694
Delete
Rename
Edit
Download
📄
deprecated.min.js
File
684
Delete
Rename
Edit
Download
📁
development
Folder
-
Delete
Rename
📄
dom-ready.js
File
2464
Delete
Rename
Edit
Download
📄
dom-ready.min.js
File
457
Delete
Rename
Edit
Download
📄
dom.js
File
62127
Delete
Rename
Edit
Download
📄
dom.min.js
File
12547
Delete
Rename
Edit
Download
📄
edit-post.js
File
123321
Delete
Rename
Edit
Download
📄
edit-post.min.js
File
42263
Delete
Rename
Edit
Download
📄
edit-site.js
File
1640694
Delete
Rename
Edit
Download
📄
edit-site.min.js
File
641138
Delete
Rename
Edit
Download
📄
edit-widgets.js
File
175604
Delete
Rename
Edit
Download
📄
edit-widgets.min.js
File
58605
Delete
Rename
Edit
Download
📄
editor.js
File
1212327
Delete
Rename
Edit
Download
📄
editor.min.js
File
396996
Delete
Rename
Edit
Download
📄
element.js
File
68130
Delete
Rename
Edit
Download
📄
element.min.js
File
11968
Delete
Rename
Edit
Download
📄
escape-html.js
File
6003
Delete
Rename
Edit
Download
📄
escape-html.min.js
File
1000
Delete
Rename
Edit
Download
📄
format-library.js
File
68467
Delete
Rename
Edit
Download
📄
format-library.min.js
File
22769
Delete
Rename
Edit
Download
📄
hooks.js
File
20687
Delete
Rename
Edit
Download
📄
hooks.min.js
File
4776
Delete
Rename
Edit
Download
📄
html-entities.js
File
3706
Delete
Rename
Edit
Download
📄
html-entities.min.js
File
788
Delete
Rename
Edit
Download
📄
i18n.js
File
49627
Delete
Rename
Edit
Download
📄
i18n.min.js
File
9141
Delete
Rename
Edit
Download
📄
is-shallow-equal.js
File
4287
Delete
Rename
Edit
Download
📄
is-shallow-equal.min.js
File
1018
Delete
Rename
Edit
Download
📄
keyboard-shortcuts.js
File
24479
Delete
Rename
Edit
Download
📄
keyboard-shortcuts.min.js
File
3017
Delete
Rename
Edit
Download
📄
keycodes.js
File
14113
Delete
Rename
Edit
Download
📄
keycodes.min.js
File
2642
Delete
Rename
Edit
Download
📄
list-reusable-blocks.js
File
31355
Delete
Rename
Edit
Download
📄
list-reusable-blocks.min.js
File
4737
Delete
Rename
Edit
Download
📄
media-utils.js
File
31462
Delete
Rename
Edit
Download
📄
media-utils.min.js
File
9968
Delete
Rename
Edit
Download
📄
notices.js
File
21989
Delete
Rename
Edit
Download
📄
notices.min.js
File
2070
Delete
Rename
Edit
Download
📄
nux.js
File
13295
Delete
Rename
Edit
Download
📄
nux.min.js
File
3509
Delete
Rename
Edit
Download
📄
patterns.js
File
64049
Delete
Rename
Edit
Download
📄
patterns.min.js
File
21454
Delete
Rename
Edit
Download
📄
plugins.js
File
18277
Delete
Rename
Edit
Download
📄
plugins.min.js
File
4284
Delete
Rename
Edit
Download
📄
preferences-persistence.js
File
30015
Delete
Rename
Edit
Download
📄
preferences-persistence.min.js
File
5625
Delete
Rename
Edit
Download
📄
preferences.js
File
25641
Delete
Rename
Edit
Download
📄
preferences.min.js
File
7012
Delete
Rename
Edit
Download
📄
primitives.js
File
6720
Delete
Rename
Edit
Download
📄
primitives.min.js
File
1655
Delete
Rename
Edit
Download
📄
priority-queue.js
File
14208
Delete
Rename
Edit
Download
📄
priority-queue.min.js
File
3378
Delete
Rename
Edit
Download
📄
private-apis.js
File
8503
Delete
Rename
Edit
Download
📄
private-apis.min.js
File
2815
Delete
Rename
Edit
Download
📄
redux-routine.js
File
23734
Delete
Rename
Edit
Download
📄
redux-routine.min.js
File
8889
Delete
Rename
Edit
Download
📄
reusable-blocks.js
File
20432
Delete
Rename
Edit
Download
📄
reusable-blocks.min.js
File
6112
Delete
Rename
Edit
Download
📄
rich-text.js
File
120684
Delete
Rename
Edit
Download
📄
rich-text.min.js
File
31005
Delete
Rename
Edit
Download
📄
router.js
File
53261
Delete
Rename
Edit
Download
📄
router.min.js
File
13532
Delete
Rename
Edit
Download
📁
script-modules
Folder
-
Delete
Rename
📄
server-side-render.js
File
14599
Delete
Rename
Edit
Download
📄
server-side-render.min.js
File
4368
Delete
Rename
Edit
Download
📄
shortcode.js
File
14578
Delete
Rename
Edit
Download
📄
shortcode.min.js
File
2900
Delete
Rename
Edit
Download
📄
style-engine.js
File
40004
Delete
Rename
Edit
Download
📄
style-engine.min.js
File
6050
Delete
Rename
Edit
Download
📄
token-list.js
File
6049
Delete
Rename
Edit
Download
📄
token-list.min.js
File
1271
Delete
Rename
Edit
Download
📄
url.js
File
34824
Delete
Rename
Edit
Download
📄
url.min.js
File
8523
Delete
Rename
Edit
Download
📁
vendor
Folder
-
Delete
Rename
📄
viewport.js
File
10465
Delete
Rename
Edit
Download
📄
viewport.min.js
File
1868
Delete
Rename
Edit
Download
📄
warning.js
File
2444
Delete
Rename
Edit
Download
📄
warning.min.js
File
311
Delete
Rename
Edit
Download
📄
widgets.js
File
53737
Delete
Rename
Edit
Download
📄
widgets.min.js
File
20034
Delete
Rename
Edit
Download
📄
wordcount.js
File
14748
Delete
Rename
Edit
Download
📄
wordcount.min.js
File
2480
Delete
Rename
Edit
Download
Upload
Create Folder
📝 Editing:
shortcode.js
Size: 14,578 bytes
Lines: 525
Type: .js
💾 Save
Cancel
✕
/******/ (() => { // webpackBootstrap /******/ "use strict"; /******/ // The require scope /******/ var __webpack_require__ = {}; /******/ /************************************************************************/ /******/ /* webpack/runtime/define property getters */ /******/ (() => { /******/ // define getter functions for harmony exports /******/ __webpack_require__.d = (exports, definition) => { /******/ for(var key in definition) { /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); /******/ } /******/ } /******/ }; /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ /******/ (() => { /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) /******/ })(); /******/ /************************************************************************/ var __webpack_exports__ = {}; // EXPORTS __webpack_require__.d(__webpack_exports__, { "default": () => (/* binding */ build_module) }); // UNUSED EXPORTS: attrs, fromMatch, next, regexp, replace, string ;// ./node_modules/memize/dist/index.js /** * Memize options object. * * @typedef MemizeOptions * * @property {number} [maxSize] Maximum size of the cache. */ /** * Internal cache entry. * * @typedef MemizeCacheNode * * @property {?MemizeCacheNode|undefined} [prev] Previous node. * @property {?MemizeCacheNode|undefined} [next] Next node. * @property {Array<*>} args Function arguments for cache * entry. * @property {*} val Function result. */ /** * Properties of the enhanced function for controlling cache. * * @typedef MemizeMemoizedFunction * * @property {()=>void} clear Clear the cache. */ /** * Accepts a function to be memoized, and returns a new memoized function, with * optional options. * * @template {(...args: any[]) => any} F * * @param {F} fn Function to memoize. * @param {MemizeOptions} [options] Options object. * * @return {((...args: Parameters<F>) => ReturnType<F>) & MemizeMemoizedFunction} Memoized function. */ function memize(fn, options) { var size = 0; /** @type {?MemizeCacheNode|undefined} */ var head; /** @type {?MemizeCacheNode|undefined} */ var tail; options = options || {}; function memoized(/* ...args */) { var node = head, len = arguments.length, args, i; searchCache: while (node) { // Perform a shallow equality test to confirm that whether the node // under test is a candidate for the arguments passed. Two arrays // are shallowly equal if their length matches and each entry is // strictly equal between the two sets. Avoid abstracting to a // function which could incur an arguments leaking deoptimization. // Check whether node arguments match arguments length if (node.args.length !== arguments.length) { node = node.next; continue; } // Check whether node arguments match arguments values for (i = 0; i < len; i++) { if (node.args[i] !== arguments[i]) { node = node.next; continue searchCache; } } // At this point we can assume we've found a match // Surface matched node to head if not already if (node !== head) { // As tail, shift to previous. Must only shift if not also // head, since if both head and tail, there is no previous. if (node === tail) { tail = node.prev; } // Adjust siblings to point to each other. If node was tail, // this also handles new tail's empty `next` assignment. /** @type {MemizeCacheNode} */ (node.prev).next = node.next; if (node.next) { node.next.prev = node.prev; } node.next = head; node.prev = null; /** @type {MemizeCacheNode} */ (head).prev = node; head = node; } // Return immediately return node.val; } // No cached value found. Continue to insertion phase: // Create a copy of arguments (avoid leaking deoptimization) args = new Array(len); for (i = 0; i < len; i++) { args[i] = arguments[i]; } node = { args: args, // Generate the result from original function val: fn.apply(null, args), }; // Don't need to check whether node is already head, since it would // have been returned above already if it was // Shift existing head down list if (head) { head.prev = node; node.next = head; } else { // If no head, follows that there's no tail (at initial or reset) tail = node; } // Trim tail if we're reached max size and are pending cache insertion if (size === /** @type {MemizeOptions} */ (options).maxSize) { tail = /** @type {MemizeCacheNode} */ (tail).prev; /** @type {MemizeCacheNode} */ (tail).next = null; } else { size++; } head = node; return node.val; } memoized.clear = function () { head = null; tail = null; size = 0; }; // Ignore reason: There's not a clear solution to create an intersection of // the function with additional properties, where the goal is to retain the // function signature of the incoming argument and add control properties // on the return value. // @ts-ignore return memoized; } ;// ./node_modules/@wordpress/shortcode/build-module/index.js /** * External dependencies */ /** * Find the next matching shortcode. * * @param {string} tag Shortcode tag. * @param {string} text Text to search. * @param {number} index Index to start search from. * * @return {import('./types').ShortcodeMatch | undefined} Matched information. */ function next(tag, text, index = 0) { const re = regexp(tag); re.lastIndex = index; const match = re.exec(text); if (!match) { return; } // If we matched an escaped shortcode, try again. if ('[' === match[1] && ']' === match[7]) { return next(tag, text, re.lastIndex); } const result = { index: match.index, content: match[0], shortcode: fromMatch(match) }; // If we matched a leading `[`, strip it from the match and increment the // index accordingly. if (match[1]) { result.content = result.content.slice(1); result.index++; } // If we matched a trailing `]`, strip it from the match. if (match[7]) { result.content = result.content.slice(0, -1); } return result; } /** * Replace matching shortcodes in a block of text. * * @param {string} tag Shortcode tag. * @param {string} text Text to search. * @param {import('./types').ReplaceCallback} callback Function to process the match and return * replacement string. * * @return {string} Text with shortcodes replaced. */ function replace(tag, text, callback) { return text.replace(regexp(tag), function (match, left, $3, attrs, slash, content, closing, right) { // If both extra brackets exist, the shortcode has been properly // escaped. if (left === '[' && right === ']') { return match; } // Create the match object and pass it through the callback. const result = callback(fromMatch(arguments)); // Make sure to return any of the extra brackets if they weren't used to // escape the shortcode. return result || result === '' ? left + result + right : match; }); } /** * Generate a string from shortcode parameters. * * Creates a shortcode instance and returns a string. * * Accepts the same `options` as the `shortcode()` constructor, containing a * `tag` string, a string or object of `attrs`, a boolean indicating whether to * format the shortcode using a `single` tag, and a `content` string. * * @param {Object} options * * @return {string} String representation of the shortcode. */ function string(options) { return new shortcode(options).string(); } /** * Generate a RegExp to identify a shortcode. * * The base regex is functionally equivalent to the one found in * `get_shortcode_regex()` in `wp-includes/shortcodes.php`. * * Capture groups: * * 1. An extra `[` to allow for escaping shortcodes with double `[[]]` * 2. The shortcode name * 3. The shortcode argument list * 4. The self closing `/` * 5. The content of a shortcode when it wraps some content. * 6. The closing tag. * 7. An extra `]` to allow for escaping shortcodes with double `[[]]` * * @param {string} tag Shortcode tag. * * @return {RegExp} Shortcode RegExp. */ function regexp(tag) { return new RegExp('\\[(\\[?)(' + tag + ')(?![\\w-])([^\\]\\/]*(?:\\/(?!\\])[^\\]\\/]*)*?)(?:(\\/)\\]|\\](?:([^\\[]*(?:\\[(?!\\/\\2\\])[^\\[]*)*)(\\[\\/\\2\\]))?)(\\]?)', 'g'); } /** * Parse shortcode attributes. * * Shortcodes accept many types of attributes. These can chiefly be divided into * named and numeric attributes: * * Named attributes are assigned on a key/value basis, while numeric attributes * are treated as an array. * * Named attributes can be formatted as either `name="value"`, `name='value'`, * or `name=value`. Numeric attributes can be formatted as `"value"` or just * `value`. * * @param {string} text Serialised shortcode attributes. * * @return {import('./types').ShortcodeAttrs} Parsed shortcode attributes. */ const attrs = memize(text => { const named = {}; const numeric = []; // This regular expression is reused from `shortcode_parse_atts()` in // `wp-includes/shortcodes.php`. // // Capture groups: // // 1. An attribute name, that corresponds to... // 2. a value in double quotes. // 3. An attribute name, that corresponds to... // 4. a value in single quotes. // 5. An attribute name, that corresponds to... // 6. an unquoted value. // 7. A numeric attribute in double quotes. // 8. A numeric attribute in single quotes. // 9. An unquoted numeric attribute. 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. text = text.replace(/[\u00a0\u200b]/g, ' '); let match; // Match and normalize attributes. while (match = pattern.exec(text)) { if (match[1]) { named[match[1].toLowerCase()] = match[2]; } else if (match[3]) { named[match[3].toLowerCase()] = match[4]; } else if (match[5]) { named[match[5].toLowerCase()] = match[6]; } else if (match[7]) { numeric.push(match[7]); } else if (match[8]) { numeric.push(match[8]); } else if (match[9]) { numeric.push(match[9]); } } return { named, numeric }; }); /** * Generate a Shortcode Object from a RegExp match. * * Accepts a `match` object from calling `regexp.exec()` on a `RegExp` generated * by `regexp()`. `match` can also be set to the `arguments` from a callback * passed to `regexp.replace()`. * * @param {import('./types').Match} match Match array. * * @return {InstanceType<import('./types').shortcode>} Shortcode instance. */ function fromMatch(match) { let type; if (match[4]) { type = 'self-closing'; } else if (match[6]) { type = 'closed'; } else { type = 'single'; } return new shortcode({ tag: match[2], attrs: match[3], type, content: match[5] }); } /** * Creates a shortcode instance. * * To access a raw representation of a shortcode, pass an `options` object, * containing a `tag` string, a string or object of `attrs`, a string indicating * the `type` of the shortcode ('single', 'self-closing', or 'closed'), and a * `content` string. * * @type {import('./types').shortcode} Shortcode instance. */ const shortcode = Object.assign(function (options) { const { tag, attrs: attributes, type, content } = options || {}; Object.assign(this, { tag, type, content }); // Ensure we have a correctly formatted `attrs` object. this.attrs = { named: {}, numeric: [] }; if (!attributes) { return; } const attributeTypes = ['named', 'numeric']; // Parse a string of attributes. if (typeof attributes === 'string') { this.attrs = attrs(attributes); // Identify a correctly formatted `attrs` object. } else if (attributes.length === attributeTypes.length && attributeTypes.every((t, key) => t === attributes[key])) { this.attrs = attributes; // Handle a flat object of attributes. } else { Object.entries(attributes).forEach(([key, value]) => { this.set(key, value); }); } }, { next, replace, string, regexp, attrs, fromMatch }); Object.assign(shortcode.prototype, { /** * Get a shortcode attribute. * * Automatically detects whether `attr` is named or numeric and routes it * accordingly. * * @param {(number|string)} attr Attribute key. * * @return {string} Attribute value. */ get(attr) { return this.attrs[typeof attr === 'number' ? 'numeric' : 'named'][attr]; }, /** * Set a shortcode attribute. * * Automatically detects whether `attr` is named or numeric and routes it * accordingly. * * @param {(number|string)} attr Attribute key. * @param {string} value Attribute value. * * @return {InstanceType< import('./types').shortcode >} Shortcode instance. */ set(attr, value) { this.attrs[typeof attr === 'number' ? 'numeric' : 'named'][attr] = value; return this; }, /** * Transform the shortcode into a string. * * @return {string} String representation of the shortcode. */ string() { let text = '[' + this.tag; this.attrs.numeric.forEach(value => { if (/\s/.test(value)) { text += ' "' + value + '"'; } else { text += ' ' + value; } }); Object.entries(this.attrs.named).forEach(([name, value]) => { text += ' ' + name + '="' + value + '"'; }); // If the tag is marked as `single` or `self-closing`, close the tag and // ignore any additional content. if ('single' === this.type) { return text + ']'; } else if ('self-closing' === this.type) { return text + ' /]'; } // Complete the opening tag. text += ']'; if (this.content) { text += this.content; } // Add the closing tag. return text + '[/' + this.tag + ']'; } }); /* harmony default export */ const build_module = (shortcode); (window.wp = window.wp || {}).shortcode = __webpack_exports__["default"]; /******/ })() ;
✅ File saved successfully!