Linux webserver 6.8.0-49-generic #49~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Wed Nov 6 17:42:15 UTC 2 x86_64
Apache/2.4.52 (Ubuntu)
Server IP : 192.168.1.1 & Your IP : 18.226.166.64
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
var /
www /
famchicpd /
wp-includes /
js /
dist /
Delete
Unzip
Name
Size
Permission
Date
Action
development
[ DIR ]
drwxr-x---
2024-01-30 19:27
script-modules
[ DIR ]
drwxr-xr-x
2024-11-13 12:45
vendor
[ DIR ]
drwxr-x---
2024-11-13 12:45
a11y.js
8.37
KB
-rw-r--r--
2025-04-15 20:02
a11y.min.js
2.3
KB
-rw-r--r--
2024-11-13 12:45
annotations.js
22.79
KB
-rw-r--r--
2025-04-15 20:02
annotations.min.js
5.39
KB
-rw-r--r--
2024-07-16 17:55
api-fetch.js
23.31
KB
-rw-r--r--
2025-04-15 20:02
api-fetch.min.js
5.7
KB
-rw-r--r--
2025-04-15 20:02
autop.js
15.61
KB
-rw-r--r--
2024-11-13 12:45
autop.min.js
5.48
KB
-rw-r--r--
2024-04-03 05:54
blob.js
4.51
KB
-rw-r--r--
2024-11-13 12:45
blob.min.js
1.08
KB
-rw-r--r--
2024-04-03 05:54
block-directory.js
78.64
KB
-rw-r--r--
2025-04-15 20:02
block-directory.min.js
20.25
KB
-rw-r--r--
2025-04-15 20:02
block-editor.js
2.6
MB
-rw-r--r--
2025-04-30 17:52
block-editor.min.js
845.71
KB
-rw-r--r--
2025-04-30 17:52
block-library.js
2.13
MB
-rw-r--r--
2025-04-15 20:02
block-library.min.js
855.64
KB
-rw-r--r--
2025-04-15 20:02
block-serialization-default-parser.js
14.87
KB
-rw-r--r--
2024-04-03 05:54
block-serialization-default-parser.min.js
2.34
KB
-rw-r--r--
2024-04-03 05:54
blocks.js
554.02
KB
-rw-r--r--
2025-04-15 20:02
blocks.min.js
169.49
KB
-rw-r--r--
2025-04-15 20:02
commands.js
178.44
KB
-rw-r--r--
2025-04-15 20:02
commands.min.js
48.27
KB
-rw-r--r--
2025-04-15 20:02
components.js
2.25
MB
-rw-r--r--
2025-04-30 17:52
components.min.js
702.15
KB
-rw-r--r--
2025-04-30 17:52
compose.js
195.61
KB
-rw-r--r--
2025-04-15 20:02
compose.min.js
35.99
KB
-rw-r--r--
2025-04-15 20:02
core-commands.js
23.83
KB
-rw-r--r--
2025-04-15 20:02
core-commands.min.js
9.2
KB
-rw-r--r--
2025-04-15 20:02
core-data.js
261.22
KB
-rw-r--r--
2025-04-15 20:02
core-data.min.js
64.24
KB
-rw-r--r--
2025-04-15 20:02
customize-widgets.js
95.33
KB
-rw-r--r--
2025-04-15 20:02
customize-widgets.min.js
34.18
KB
-rw-r--r--
2025-04-15 20:02
data-controls.js
7.07
KB
-rw-r--r--
2025-04-15 20:02
data-controls.min.js
1.44
KB
-rw-r--r--
2024-04-03 05:54
data.js
141.55
KB
-rw-r--r--
2025-04-15 20:02
data.min.js
25
KB
-rw-r--r--
2025-04-15 20:02
date.js
798.41
KB
-rw-r--r--
2025-04-15 20:02
date.min.js
765.06
KB
-rw-r--r--
2025-04-15 20:02
deprecated.js
4.58
KB
-rw-r--r--
2025-04-15 20:02
deprecated.min.js
684
B
-rw-r--r--
2024-04-03 05:54
dom-ready.js
2.41
KB
-rw-r--r--
2024-04-03 05:54
dom-ready.min.js
457
B
-rw-r--r--
2024-04-03 05:54
dom.js
60.66
KB
-rw-r--r--
2025-04-15 20:02
dom.min.js
12.24
KB
-rw-r--r--
2025-04-15 20:02
edit-post.js
120.43
KB
-rw-r--r--
2025-04-30 17:52
edit-post.min.js
41.27
KB
-rw-r--r--
2025-04-30 17:52
edit-site.js
1.56
MB
-rw-r--r--
2025-04-15 20:02
edit-site.min.js
626.11
KB
-rw-r--r--
2025-04-15 20:02
edit-widgets.js
171.49
KB
-rw-r--r--
2025-04-15 20:02
edit-widgets.min.js
57.23
KB
-rw-r--r--
2025-04-15 20:02
editor.js
1.16
MB
-rw-r--r--
2025-04-30 17:52
editor.min.js
387.69
KB
-rw-r--r--
2025-04-30 17:52
element.js
66.53
KB
-rw-r--r--
2025-04-15 20:02
element.min.js
11.69
KB
-rw-r--r--
2025-04-15 20:02
escape-html.js
5.86
KB
-rw-r--r--
2025-04-15 20:02
escape-html.min.js
1000
B
-rw-r--r--
2024-04-03 05:54
format-library.js
66.86
KB
-rw-r--r--
2025-04-15 20:02
format-library.min.js
22.24
KB
-rw-r--r--
2025-04-15 20:02
hooks.js
20.2
KB
-rw-r--r--
2025-04-15 20:02
hooks.min.js
4.66
KB
-rw-r--r--
2024-11-13 12:45
html-entities.js
3.62
KB
-rw-r--r--
2024-07-16 17:55
html-entities.min.js
788
B
-rw-r--r--
2024-04-03 05:54
i18n.js
48.46
KB
-rw-r--r--
2025-04-15 20:02
i18n.min.js
8.93
KB
-rw-r--r--
2024-04-03 05:54
is-shallow-equal.js
4.19
KB
-rw-r--r--
2025-04-15 20:02
is-shallow-equal.min.js
1018
B
-rw-r--r--
2024-04-03 05:54
keyboard-shortcuts.js
23.91
KB
-rw-r--r--
2025-04-15 20:02
keyboard-shortcuts.min.js
2.95
KB
-rw-r--r--
2024-07-16 17:55
keycodes.js
13.78
KB
-rw-r--r--
2025-04-15 20:02
keycodes.min.js
2.58
KB
-rw-r--r--
2024-04-03 05:54
list-reusable-blocks.js
30.62
KB
-rw-r--r--
2025-04-15 20:02
list-reusable-blocks.min.js
4.63
KB
-rw-r--r--
2025-04-15 20:02
media-utils.js
30.72
KB
-rw-r--r--
2025-04-15 20:02
media-utils.min.js
9.73
KB
-rw-r--r--
2025-04-15 20:02
notices.js
21.47
KB
-rw-r--r--
2025-04-15 20:02
notices.min.js
2.02
KB
-rw-r--r--
2024-04-03 05:54
nux.js
12.98
KB
-rw-r--r--
2025-04-15 20:02
nux.min.js
3.43
KB
-rw-r--r--
2024-11-13 12:45
patterns.js
62.55
KB
-rw-r--r--
2025-04-15 20:02
patterns.min.js
20.95
KB
-rw-r--r--
2025-04-15 20:02
plugins.js
17.85
KB
-rw-r--r--
2025-04-15 20:02
plugins.min.js
4.18
KB
-rw-r--r--
2025-04-15 20:02
preferences-persistence.js
29.31
KB
-rw-r--r--
2025-04-15 20:02
preferences-persistence.min.js
5.49
KB
-rw-r--r--
2024-07-16 17:55
preferences.js
25.04
KB
-rw-r--r--
2025-04-15 20:02
preferences.min.js
6.85
KB
-rw-r--r--
2025-04-15 20:02
primitives.js
6.56
KB
-rw-r--r--
2025-04-15 20:02
primitives.min.js
1.62
KB
-rw-r--r--
2024-07-16 17:55
priority-queue.js
13.88
KB
-rw-r--r--
2025-04-15 20:02
priority-queue.min.js
3.3
KB
-rw-r--r--
2024-04-03 05:54
private-apis.js
8.3
KB
-rw-r--r--
2025-04-15 20:02
private-apis.min.js
2.75
KB
-rw-r--r--
2025-04-15 20:02
redux-routine.js
23.18
KB
-rw-r--r--
2025-04-15 20:02
redux-routine.min.js
8.68
KB
-rw-r--r--
2025-04-15 20:02
reusable-blocks.js
19.95
KB
-rw-r--r--
2025-04-15 20:02
reusable-blocks.min.js
5.97
KB
-rw-r--r--
2024-11-13 12:45
rich-text.js
117.86
KB
-rw-r--r--
2025-04-15 20:02
rich-text.min.js
30.28
KB
-rw-r--r--
2025-04-15 20:02
router.js
52.01
KB
-rw-r--r--
2025-04-15 20:02
router.min.js
13.21
KB
-rw-r--r--
2025-04-15 20:02
server-side-render.js
14.26
KB
-rw-r--r--
2025-04-15 20:02
server-side-render.min.js
4.27
KB
-rw-r--r--
2025-04-15 20:02
shortcode.js
14.24
KB
-rw-r--r--
2025-04-15 20:02
shortcode.min.js
2.83
KB
-rw-r--r--
2024-04-03 05:54
style-engine.js
39.07
KB
-rw-r--r--
2025-04-15 20:02
style-engine.min.js
5.91
KB
-rw-r--r--
2024-11-13 12:45
token-list.js
5.91
KB
-rw-r--r--
2024-11-13 12:45
token-list.min.js
1.24
KB
-rw-r--r--
2024-11-13 12:45
url.js
33.85
KB
-rw-r--r--
2025-04-15 20:02
url.min.js
8.26
KB
-rw-r--r--
2025-04-15 20:02
viewport.js
10.22
KB
-rw-r--r--
2025-04-15 20:02
viewport.min.js
1.82
KB
-rw-r--r--
2024-07-16 17:55
warning.js
2.39
KB
-rw-r--r--
2025-04-15 20:02
warning.min.js
311
B
-rw-r--r--
2024-04-03 05:54
widgets.js
52.48
KB
-rw-r--r--
2025-04-15 20:02
widgets.min.js
19.56
KB
-rw-r--r--
2025-04-15 20:02
wordcount.js
14.4
KB
-rw-r--r--
2025-04-15 20:02
wordcount.min.js
2.42
KB
-rw-r--r--
2024-04-03 05:54
Save
Rename
/******/ (() => { // 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)) /******/ })(); /******/ /******/ /* webpack/runtime/make namespace object */ /******/ (() => { /******/ // define __esModule on exports /******/ __webpack_require__.r = (exports) => { /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); /******/ } /******/ Object.defineProperty(exports, '__esModule', { value: true }); /******/ }; /******/ })(); /******/ /************************************************************************/ var __webpack_exports__ = {}; __webpack_require__.r(__webpack_exports__); /* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ autop: () => (/* binding */ autop), /* harmony export */ removep: () => (/* binding */ removep) /* harmony export */ }); /** * The regular expression for an HTML element. */ const htmlSplitRegex = (() => { /* eslint-disable no-multi-spaces */ const comments = '!' + // Start of comment, after the <. '(?:' + // Unroll the loop: Consume everything until --> is found. '-(?!->)' + // Dash not followed by end of comment. '[^\\-]*' + // Consume non-dashes. ')*' + // Loop possessively. '(?:-->)?'; // End of comment. If not found, match all input. const cdata = '!\\[CDATA\\[' + // Start of comment, after the <. '[^\\]]*' + // Consume non-]. '(?:' + // Unroll the loop: Consume everything until ]]> is found. '](?!]>)' + // One ] not followed by end of comment. '[^\\]]*' + // Consume non-]. ')*?' + // Loop possessively. '(?:]]>)?'; // End of comment. If not found, match all input. const escaped = '(?=' + // Is the element escaped? '!--' + '|' + '!\\[CDATA\\[' + ')' + '((?=!-)' + // If yes, which type? comments + '|' + cdata + ')'; const regex = '(' + // Capture the entire match. '<' + // Find start of element. '(' + // Conditional expression follows. escaped + // Find end of escaped element. '|' + // ... else ... '[^>]*>?' + // Find end of normal element. ')' + ')'; return new RegExp(regex); /* eslint-enable no-multi-spaces */ })(); /** * Separate HTML elements and comments from the text. * * @param input The text which has to be formatted. * * @return The formatted text. */ function htmlSplit(input) { const parts = []; let workingInput = input; let match; while (match = workingInput.match(htmlSplitRegex)) { // The `match` result, when invoked on a RegExp with the `g` flag (`/foo/g`) will not include `index`. // If the `g` flag is omitted, `index` is included. // `htmlSplitRegex` does not have the `g` flag so we can assert it will have an index number. // Assert `match.index` is a number. const index = match.index; parts.push(workingInput.slice(0, index)); parts.push(match[0]); workingInput = workingInput.slice(index + match[0].length); } if (workingInput.length) { parts.push(workingInput); } return parts; } /** * Replace characters or phrases within HTML elements only. * * @param haystack The text which has to be formatted. * @param replacePairs In the form {from: 'to', …}. * * @return The formatted text. */ function replaceInHtmlTags(haystack, replacePairs) { // Find all elements. const textArr = htmlSplit(haystack); let changed = false; // Extract all needles. const needles = Object.keys(replacePairs); // Loop through delimiters (elements) only. for (let i = 1; i < textArr.length; i += 2) { for (let j = 0; j < needles.length; j++) { const needle = needles[j]; if (-1 !== textArr[i].indexOf(needle)) { textArr[i] = textArr[i].replace(new RegExp(needle, 'g'), replacePairs[needle]); changed = true; // After one strtr() break out of the foreach loop and look at next element. break; } } } if (changed) { haystack = textArr.join(''); } return haystack; } /** * Replaces double line-breaks with paragraph elements. * * A group of regex replaces used to identify text formatted with newlines and * replace double line-breaks with HTML paragraph tags. The remaining line- * breaks after conversion become `<br />` tags, unless br is set to 'false'. * * @param text The text which has to be formatted. * @param br Optional. If set, will convert all remaining line- * breaks after paragraphing. Default true. * * @example *```js * import { autop } from '@wordpress/autop'; * autop( 'my text' ); // "<p>my text</p>" * ``` * * @return Text which has been converted into paragraph tags. */ function autop(text, br = true) { const preTags = []; if (text.trim() === '') { return ''; } // Just to make things a little easier, pad the end. text = text + '\n'; /* * Pre tags shouldn't be touched by autop. * Replace pre tags with placeholders and bring them back after autop. */ if (text.indexOf('<pre') !== -1) { const textParts = text.split('</pre>'); const lastText = textParts.pop(); text = ''; for (let i = 0; i < textParts.length; i++) { const textPart = textParts[i]; const start = textPart.indexOf('<pre'); // Malformed html? if (start === -1) { text += textPart; continue; } const name = '<pre wp-pre-tag-' + i + '></pre>'; preTags.push([name, textPart.substr(start) + '</pre>']); text += textPart.substr(0, start) + name; } text += lastText; } // Change multiple <br>s into two line breaks, which will turn into paragraphs. text = text.replace(/<br\s*\/?>\s*<br\s*\/?>/g, '\n\n'); const allBlocks = '(?:table|thead|tfoot|caption|col|colgroup|tbody|tr|td|th|div|dl|dd|dt|ul|ol|li|pre|form|map|area|blockquote|address|math|style|p|h[1-6]|hr|fieldset|legend|section|article|aside|hgroup|header|footer|nav|figure|figcaption|details|menu|summary)'; // Add a double line break above block-level opening tags. text = text.replace(new RegExp('(<' + allBlocks + '[\\s/>])', 'g'), '\n\n$1'); // Add a double line break below block-level closing tags. text = text.replace(new RegExp('(</' + allBlocks + '>)', 'g'), '$1\n\n'); // Standardize newline characters to "\n". text = text.replace(/\r\n|\r/g, '\n'); // Find newlines in all elements and add placeholders. text = replaceInHtmlTags(text, { '\n': ' <!-- wpnl --> ' }); // Collapse line breaks before and after <option> elements so they don't get autop'd. if (text.indexOf('<option') !== -1) { text = text.replace(/\s*<option/g, '<option'); text = text.replace(/<\/option>\s*/g, '</option>'); } /* * Collapse line breaks inside <object> elements, before <param> and <embed> elements * so they don't get autop'd. */ if (text.indexOf('</object>') !== -1) { text = text.replace(/(<object[^>]*>)\s*/g, '$1'); text = text.replace(/\s*<\/object>/g, '</object>'); text = text.replace(/\s*(<\/?(?:param|embed)[^>]*>)\s*/g, '$1'); } /* * Collapse line breaks inside <audio> and <video> elements, * before and after <source> and <track> elements. */ if (text.indexOf('<source') !== -1 || text.indexOf('<track') !== -1) { text = text.replace(/([<\[](?:audio|video)[^>\]]*[>\]])\s*/g, '$1'); text = text.replace(/\s*([<\[]\/(?:audio|video)[>\]])/g, '$1'); text = text.replace(/\s*(<(?:source|track)[^>]*>)\s*/g, '$1'); } // Collapse line breaks before and after <figcaption> elements. if (text.indexOf('<figcaption') !== -1) { text = text.replace(/\s*(<figcaption[^>]*>)/, '$1'); text = text.replace(/<\/figcaption>\s*/, '</figcaption>'); } // Remove more than two contiguous line breaks. text = text.replace(/\n\n+/g, '\n\n'); // Split up the contents into an array of strings, separated by double line breaks. const texts = text.split(/\n\s*\n/).filter(Boolean); // Reset text prior to rebuilding. text = ''; // Rebuild the content as a string, wrapping every bit with a <p>. texts.forEach(textPiece => { text += '<p>' + textPiece.replace(/^\n*|\n*$/g, '') + '</p>\n'; }); // Under certain strange conditions it could create a P of entirely whitespace. text = text.replace(/<p>\s*<\/p>/g, ''); // Add a closing <p> inside <div>, <address>, or <form> tag if missing. text = text.replace(/<p>([^<]+)<\/(div|address|form)>/g, '<p>$1</p></$2>'); // If an opening or closing block element tag is wrapped in a <p>, unwrap it. text = text.replace(new RegExp('<p>\\s*(</?' + allBlocks + '[^>]*>)\\s*</p>', 'g'), '$1'); // In some cases <li> may get wrapped in <p>, fix them. text = text.replace(/<p>(<li.+?)<\/p>/g, '$1'); // If a <blockquote> is wrapped with a <p>, move it inside the <blockquote>. text = text.replace(/<p><blockquote([^>]*)>/gi, '<blockquote$1><p>'); text = text.replace(/<\/blockquote><\/p>/g, '</p></blockquote>'); // If an opening or closing block element tag is preceded by an opening <p> tag, remove it. text = text.replace(new RegExp('<p>\\s*(</?' + allBlocks + '[^>]*>)', 'g'), '$1'); // If an opening or closing block element tag is followed by a closing <p> tag, remove it. text = text.replace(new RegExp('(</?' + allBlocks + '[^>]*>)\\s*</p>', 'g'), '$1'); // Optionally insert line breaks. if (br) { // Replace newlines that shouldn't be touched with a placeholder. text = text.replace(/<(script|style).*?<\/\\1>/g, match => match[0].replace(/\n/g, '<WPPreserveNewline />')); // Normalize <br> text = text.replace(/<br>|<br\/>/g, '<br />'); // Replace any new line characters that aren't preceded by a <br /> with a <br />. text = text.replace(/(<br \/>)?\s*\n/g, (a, b) => b ? a : '<br />\n'); // Replace newline placeholders with newlines. text = text.replace(/<WPPreserveNewline \/>/g, '\n'); } // If a <br /> tag is after an opening or closing block tag, remove it. text = text.replace(new RegExp('(</?' + allBlocks + '[^>]*>)\\s*<br />', 'g'), '$1'); // If a <br /> tag is before a subset of opening or closing block tags, remove it. text = text.replace(/<br \/>(\s*<\/?(?:p|li|div|dl|dd|dt|th|pre|td|ul|ol)[^>]*>)/g, '$1'); text = text.replace(/\n<\/p>$/g, '</p>'); // Replace placeholder <pre> tags with their original content. preTags.forEach(preTag => { const [name, original] = preTag; text = text.replace(name, original); }); // Restore newlines in all elements. if (-1 !== text.indexOf('<!-- wpnl -->')) { text = text.replace(/\s?<!-- wpnl -->\s?/g, '\n'); } return text; } /** * Replaces `<p>` tags with two line breaks. "Opposite" of autop(). * * Replaces `<p>` tags with two line breaks except where the `<p>` has attributes. * Unifies whitespace. Indents `<li>`, `<dt>` and `<dd>` for better readability. * * @param html The content from the editor. * * @example * ```js * import { removep } from '@wordpress/autop'; * removep( '<p>my text</p>' ); // "my text" * ``` * * @return The content with stripped paragraph tags. */ function removep(html) { const blocklist = 'blockquote|ul|ol|li|dl|dt|dd|table|thead|tbody|tfoot|tr|th|td|h[1-6]|fieldset|figure'; const blocklist1 = blocklist + '|div|p'; const blocklist2 = blocklist + '|pre'; const preserve = []; let preserveLinebreaks = false; let preserveBr = false; if (!html) { return ''; } // Protect script and style tags. if (html.indexOf('<script') !== -1 || html.indexOf('<style') !== -1) { html = html.replace(/<(script|style)[^>]*>[\s\S]*?<\/\1>/g, match => { preserve.push(match); return '<wp-preserve>'; }); } // Protect pre tags. if (html.indexOf('<pre') !== -1) { preserveLinebreaks = true; html = html.replace(/<pre[^>]*>[\s\S]+?<\/pre>/g, a => { a = a.replace(/<br ?\/?>(\r\n|\n)?/g, '<wp-line-break>'); a = a.replace(/<\/?p( [^>]*)?>(\r\n|\n)?/g, '<wp-line-break>'); return a.replace(/\r?\n/g, '<wp-line-break>'); }); } // Remove line breaks but keep <br> tags inside image captions. if (html.indexOf('[caption') !== -1) { preserveBr = true; html = html.replace(/\[caption[\s\S]+?\[\/caption\]/g, a => { return a.replace(/<br([^>]*)>/g, '<wp-temp-br$1>').replace(/[\r\n\t]+/, ''); }); } // Normalize white space characters before and after block tags. html = html.replace(new RegExp('\\s*</(' + blocklist1 + ')>\\s*', 'g'), '</$1>\n'); html = html.replace(new RegExp('\\s*<((?:' + blocklist1 + ')(?: [^>]*)?)>', 'g'), '\n<$1>'); // Mark </p> if it has any attributes. html = html.replace(/(<p [^>]+>[\s\S]*?)<\/p>/g, '$1</p#>'); // Preserve the first <p> inside a <div>. html = html.replace(/<div( [^>]*)?>\s*<p>/gi, '<div$1>\n\n'); // Remove paragraph tags. html = html.replace(/\s*<p>/gi, ''); html = html.replace(/\s*<\/p>\s*/gi, '\n\n'); // Normalize white space chars and remove multiple line breaks. html = html.replace(/\n[\s\u00a0]+\n/g, '\n\n'); // Replace <br> tags with line breaks. html = html.replace(/(\s*)<br ?\/?>\s*/gi, (_, space) => { if (space && space.indexOf('\n') !== -1) { return '\n\n'; } return '\n'; }); // Fix line breaks around <div>. html = html.replace(/\s*<div/g, '\n<div'); html = html.replace(/<\/div>\s*/g, '</div>\n'); // Fix line breaks around caption shortcodes. html = html.replace(/\s*\[caption([^\[]+)\[\/caption\]\s*/gi, '\n\n[caption$1[/caption]\n\n'); html = html.replace(/caption\]\n\n+\[caption/g, 'caption]\n\n[caption'); // Pad block elements tags with a line break. html = html.replace(new RegExp('\\s*<((?:' + blocklist2 + ')(?: [^>]*)?)\\s*>', 'g'), '\n<$1>'); html = html.replace(new RegExp('\\s*</(' + blocklist2 + ')>\\s*', 'g'), '</$1>\n'); // Indent <li>, <dt> and <dd> tags. html = html.replace(/<((li|dt|dd)[^>]*)>/g, ' \t<$1>'); // Fix line breaks around <select> and <option>. if (html.indexOf('<option') !== -1) { html = html.replace(/\s*<option/g, '\n<option'); html = html.replace(/\s*<\/select>/g, '\n</select>'); } // Pad <hr> with two line breaks. if (html.indexOf('<hr') !== -1) { html = html.replace(/\s*<hr( [^>]*)?>\s*/g, '\n\n<hr$1>\n\n'); } // Remove line breaks in <object> tags. if (html.indexOf('<object') !== -1) { html = html.replace(/<object[\s\S]+?<\/object>/g, a => { return a.replace(/[\r\n]+/g, ''); }); } // Unmark special paragraph closing tags. html = html.replace(/<\/p#>/g, '</p>\n'); // Pad remaining <p> tags whit a line break. html = html.replace(/\s*(<p [^>]+>[\s\S]*?<\/p>)/g, '\n$1'); // Trim. html = html.replace(/^\s+/, ''); html = html.replace(/[\s\u00a0]+$/, ''); if (preserveLinebreaks) { html = html.replace(/<wp-line-break>/g, '\n'); } if (preserveBr) { html = html.replace(/<wp-temp-br([^>]*)>/g, '<br$1>'); } // Restore preserved tags. if (preserve.length) { html = html.replace(/<wp-preserve>/g, () => { return preserve.shift(); }); } return html; } (window.wp = window.wp || {}).autop = __webpack_exports__; /******/ })() ;