Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/wp-conte.../plugins/embedpre.../assets/js
File: preview.js
/**
[0] Fix | Delete
* @package EmbedPress
[1] Fix | Delete
* @author EmbedPress <help@embedpress.com>
[2] Fix | Delete
* @copyright Copyright (C) 2018 EmbedPress. All rights reserved.
[3] Fix | Delete
* @license GPLv2 or later
[4] Fix | Delete
* @since 1.0
[5] Fix | Delete
*/
[6] Fix | Delete
(function ($, String, $data, undefined) {
[7] Fix | Delete
'use strict';
[8] Fix | Delete
[9] Fix | Delete
$(window.document).ready(function () {
[10] Fix | Delete
String.prototype.capitalizeFirstLetter = function () {
[11] Fix | Delete
return this.charAt(0).toUpperCase() + this.slice(1);
[12] Fix | Delete
};
[13] Fix | Delete
[14] Fix | Delete
String.prototype.isValidUrl = function () {
[15] Fix | Delete
var rule = /^(https?|embedpresss?):\/\//i;
[16] Fix | Delete
[17] Fix | Delete
return rule.test(this.toString());
[18] Fix | Delete
};
[19] Fix | Delete
[20] Fix | Delete
String.prototype.hasShortcode = function (shortcode) {
[21] Fix | Delete
var shortcodeRule = new RegExp('\\[' + shortcode + '(?:\\]|.+?\\])', 'ig');
[22] Fix | Delete
return !!this.toString().match(shortcodeRule);
[23] Fix | Delete
};
[24] Fix | Delete
[25] Fix | Delete
String.prototype.stripShortcode = function (shortcode) {
[26] Fix | Delete
var stripRule = new RegExp('(\\[' + shortcode + '(?:\\]|.+?\\])|\\[\\/' + shortcode + '\\])', 'ig');
[27] Fix | Delete
return this.toString().replace(stripRule, '');
[28] Fix | Delete
};
[29] Fix | Delete
[30] Fix | Delete
String.prototype.setShortcodeAttribute = function (attr, value, shortcode, replaceInsteadOfMerge) {
[31] Fix | Delete
replaceInsteadOfMerge = typeof replaceInsteadOfMerge === 'undefined' ? false : replaceInsteadOfMerge;
[32] Fix | Delete
var subject = this.toString();
[33] Fix | Delete
[34] Fix | Delete
if (subject.hasShortcode(shortcode)) {
[35] Fix | Delete
var attributes = subject.getShortcodeAttributes(shortcode);
[36] Fix | Delete
[37] Fix | Delete
if (attributes.hasOwnProperty(attr)) {
[38] Fix | Delete
if (replaceInsteadOfMerge) {
[39] Fix | Delete
attributes[attr] = value;
[40] Fix | Delete
} else {
[41] Fix | Delete
attributes[attr] += ' ' + value;
[42] Fix | Delete
}
[43] Fix | Delete
} else {
[44] Fix | Delete
attributes[attr] = value;
[45] Fix | Delete
}
[46] Fix | Delete
[47] Fix | Delete
if (!!Object.keys(attributes).length) {
[48] Fix | Delete
var parsedAttributes = [];
[49] Fix | Delete
for (var ats in attributes) {
[50] Fix | Delete
parsedAttributes.push(ats + '="' + attributes[ats] + '"');
[51] Fix | Delete
}
[52] Fix | Delete
[53] Fix | Delete
subject = '[' + shortcode + ' ' + parsedAttributes.join(' ') + ']' + subject.stripShortcode(shortcode) + '[/' + shortcode + ']';
[54] Fix | Delete
} else {
[55] Fix | Delete
subject = '[' + shortcode + ']' + subject.stripShortcode(shortcode) + '[/' + shortcode + ']';
[56] Fix | Delete
}
[57] Fix | Delete
[58] Fix | Delete
return subject;
[59] Fix | Delete
} else {
[60] Fix | Delete
return subject;
[61] Fix | Delete
}
[62] Fix | Delete
};
[63] Fix | Delete
[64] Fix | Delete
String.prototype.getShortcodeAttributes = function (shortcode) {
[65] Fix | Delete
var subject = this.toString();
[66] Fix | Delete
if (subject.hasShortcode(shortcode)) {
[67] Fix | Delete
var attributes = {};
[68] Fix | Delete
var propertiesString = (new RegExp(/\[embed\s*(.*?)\]/ig)).exec(subject)[1]; // Separate all shortcode attributes from the rest of the string
[69] Fix | Delete
if (propertiesString.length > 0) {
[70] Fix | Delete
var extractAttributesRule = new RegExp(/(\!?\w+-?\w*)(?:="(.+?)")?/ig); // Extract attributes and their values
[71] Fix | Delete
var match;
[72] Fix | Delete
while (match = extractAttributesRule.exec(propertiesString)) {
[73] Fix | Delete
var attrName = match[1];
[74] Fix | Delete
var attrValue;
[75] Fix | Delete
if (match[2] === undefined) {
[76] Fix | Delete
// Prevent `class` property being empty an treated as a boolean param
[77] Fix | Delete
if (attrName.toLowerCase() !== 'class') {
[78] Fix | Delete
if (attrName.indexOf('!') === 0) {
[79] Fix | Delete
attrName = attrName.replace('!', '');
[80] Fix | Delete
attrValue = 'false';
[81] Fix | Delete
} else {
[82] Fix | Delete
attrValue = 'true';
[83] Fix | Delete
}
[84] Fix | Delete
[85] Fix | Delete
attributes[attrName] = attrValue;
[86] Fix | Delete
}
[87] Fix | Delete
} else {
[88] Fix | Delete
attrValue = match[2];
[89] Fix | Delete
if (attrValue.isBoolean()) {
[90] Fix | Delete
attrValue = attrValue.isFalse() ? 'false' : 'true';
[91] Fix | Delete
}
[92] Fix | Delete
[93] Fix | Delete
attributes[attrName] = attrValue;
[94] Fix | Delete
}
[95] Fix | Delete
}
[96] Fix | Delete
match = extractAttributesRule = null;
[97] Fix | Delete
}
[98] Fix | Delete
propertiesString = null;
[99] Fix | Delete
[100] Fix | Delete
return attributes;
[101] Fix | Delete
} else {
[102] Fix | Delete
return {};
[103] Fix | Delete
}
[104] Fix | Delete
};
[105] Fix | Delete
[106] Fix | Delete
String.prototype.isBoolean = function () {
[107] Fix | Delete
var subject = this.toString().trim().toLowerCase();
[108] Fix | Delete
[109] Fix | Delete
return subject.isTrue(false) || subject.isFalse();
[110] Fix | Delete
};
[111] Fix | Delete
[112] Fix | Delete
String.prototype.isTrue = function (defaultValue) {
[113] Fix | Delete
var subject = this.toString().trim().toLowerCase();
[114] Fix | Delete
defaultValue = typeof defaultValue === undefined ? true : defaultValue;
[115] Fix | Delete
[116] Fix | Delete
switch (subject) {
[117] Fix | Delete
case '':
[118] Fix | Delete
defaultValue += '';
[119] Fix | Delete
return !defaultValue.isFalse();
[120] Fix | Delete
case '1':
[121] Fix | Delete
case 'true':
[122] Fix | Delete
case 'on':
[123] Fix | Delete
case 'yes':
[124] Fix | Delete
case 'y':
[125] Fix | Delete
return true;
[126] Fix | Delete
default:
[127] Fix | Delete
return false;
[128] Fix | Delete
}
[129] Fix | Delete
};
[130] Fix | Delete
[131] Fix | Delete
String.prototype.isFalse = function () {
[132] Fix | Delete
var subject = this.toString().trim().toLowerCase();
[133] Fix | Delete
[134] Fix | Delete
switch (subject) {
[135] Fix | Delete
case '0':
[136] Fix | Delete
case 'false':
[137] Fix | Delete
case 'off':
[138] Fix | Delete
case 'no':
[139] Fix | Delete
case 'n':
[140] Fix | Delete
case 'nil':
[141] Fix | Delete
case 'null':
[142] Fix | Delete
return true;
[143] Fix | Delete
default:
[144] Fix | Delete
return false;
[145] Fix | Delete
}
[146] Fix | Delete
};
[147] Fix | Delete
[148] Fix | Delete
var SHORTCODE_REGEXP = new RegExp('\\[\/?' + $data.EMBEDPRESS_SHORTCODE + '\\]', 'gi');
[149] Fix | Delete
[150] Fix | Delete
var EmbedPress = function () {
[151] Fix | Delete
var self = this;
[152] Fix | Delete
[153] Fix | Delete
var PLG_SYSTEM_ASSETS_CSS_PATH = $data.EMBEDPRESS_URL_ASSETS + 'css';
[154] Fix | Delete
var PLG_CONTENT_ASSETS_CSS_PATH = PLG_SYSTEM_ASSETS_CSS_PATH;
[155] Fix | Delete
[156] Fix | Delete
/**
[157] Fix | Delete
* The default params
[158] Fix | Delete
*
[159] Fix | Delete
* @type Object
[160] Fix | Delete
*/
[161] Fix | Delete
self.params = {
[162] Fix | Delete
baseUrl: '',
[163] Fix | Delete
versionUID: '0'
[164] Fix | Delete
};
[165] Fix | Delete
[166] Fix | Delete
/**
[167] Fix | Delete
* True, if user agent is iOS
[168] Fix | Delete
* @type Boolean True, if is iOS
[169] Fix | Delete
*/
[170] Fix | Delete
self.iOS = /iPad|iPod|iPhone/.test(window.navigator.userAgent);
[171] Fix | Delete
[172] Fix | Delete
/**
[173] Fix | Delete
* The active wrapper, activated by the mouse enter event
[174] Fix | Delete
* @type Element
[175] Fix | Delete
*/
[176] Fix | Delete
self.activeWrapper = null;
[177] Fix | Delete
[178] Fix | Delete
self.activeWrapperForModal = null;
[179] Fix | Delete
[180] Fix | Delete
/**
[181] Fix | Delete
* The active controller panel
[182] Fix | Delete
* @type Element
[183] Fix | Delete
*/
[184] Fix | Delete
self.activeControllerPanel = null;
[185] Fix | Delete
[186] Fix | Delete
/**
[187] Fix | Delete
* A list containing all loaded editor instances on the page
[188] Fix | Delete
* @type Array
[189] Fix | Delete
*/
[190] Fix | Delete
self.loadedEditors = [];
[191] Fix | Delete
[192] Fix | Delete
/**
[193] Fix | Delete
* Init the plugin
[194] Fix | Delete
*
[195] Fix | Delete
* @param object params Override the plugin's params
[196] Fix | Delete
* @return void
[197] Fix | Delete
*/
[198] Fix | Delete
self.init = function (params) {
[199] Fix | Delete
$.extend(self.params, params);
[200] Fix | Delete
[201] Fix | Delete
// Fix iOS doesn't firing click events on 'standard' elements
[202] Fix | Delete
if (self.iOS) {
[203] Fix | Delete
$(window.document.body).css('cursor', 'pointer');
[204] Fix | Delete
}
[205] Fix | Delete
[206] Fix | Delete
$(self.onReady);
[207] Fix | Delete
};
[208] Fix | Delete
[209] Fix | Delete
self.addEvent = function (event, element, callback) {
[210] Fix | Delete
if (typeof element.on !== 'undefined') {
[211] Fix | Delete
element.on(event, callback);
[212] Fix | Delete
} else {
[213] Fix | Delete
if (element['on' + event.capitalizeFirstLetter()]) {
[214] Fix | Delete
element['on' + event.capitalizeFirstLetter()].add(callback);
[215] Fix | Delete
}
[216] Fix | Delete
}
[217] Fix | Delete
};
[218] Fix | Delete
[219] Fix | Delete
self.isEmpty = function (list) {
[220] Fix | Delete
return list.length === 0;
[221] Fix | Delete
};
[222] Fix | Delete
[223] Fix | Delete
self.isDefined = function (attribute) {
[224] Fix | Delete
return (typeof attribute !== 'undefined') && (attribute !== null);
[225] Fix | Delete
};
[226] Fix | Delete
[227] Fix | Delete
self.makeId = function () {
[228] Fix | Delete
var text = '';
[229] Fix | Delete
var possible = 'abcdefghijklmnopqrstuvwxyz0123456789';
[230] Fix | Delete
[231] Fix | Delete
for (var i = 0; i < 5; i++)
[232] Fix | Delete
text += possible.charAt(Math.floor(Math.random() * possible.length));
[233] Fix | Delete
[234] Fix | Delete
return text;
[235] Fix | Delete
};
[236] Fix | Delete
[237] Fix | Delete
self.loadAsyncDynamicJsCodeFromElement = function (subject, wrapper, editorInstance) {
[238] Fix | Delete
subject = $(subject);
[239] Fix | Delete
if (subject.prop('tagName') && subject.prop('tagName').toLowerCase() === 'script') {
[240] Fix | Delete
var scriptSrc = subject.attr('src') || null;
[241] Fix | Delete
if (!scriptSrc) {
[242] Fix | Delete
self.addScriptDeclaration(wrapper, subject.html(), editorInstance);
[243] Fix | Delete
} else {
[244] Fix | Delete
self.addScript(scriptSrc, null, wrapper, editorInstance);
[245] Fix | Delete
}
[246] Fix | Delete
} else {
[247] Fix | Delete
var innerScriptsList = $('script', subject);
[248] Fix | Delete
if (innerScriptsList.length > 0) {
[249] Fix | Delete
$.each(innerScriptsList, function (innerScriptIndex, innerScript) {
[250] Fix | Delete
self.loadAsyncDynamicJsCodeFromElement(innerScript, wrapper, editorInstance);
[251] Fix | Delete
});
[252] Fix | Delete
}
[253] Fix | Delete
}
[254] Fix | Delete
};
[255] Fix | Delete
[256] Fix | Delete
/**
[257] Fix | Delete
* Method executed on the document ready event
[258] Fix | Delete
*
[259] Fix | Delete
* @return void
[260] Fix | Delete
*/
[261] Fix | Delete
self.onReady = function () {
[262] Fix | Delete
var findEditors = function () {
[263] Fix | Delete
// Wait until the editor is available
[264] Fix | Delete
var interval = window.setInterval(
[265] Fix | Delete
function () {
[266] Fix | Delete
var editorsFound = self.getEditors();
[267] Fix | Delete
if (editorsFound.length) {
[268] Fix | Delete
self.loadedEditors = editorsFound;
[269] Fix | Delete
[270] Fix | Delete
for (var editorIndex = 0; editorIndex < self.loadedEditors.length; editorIndex++) {
[271] Fix | Delete
self.onFindEditor(self.loadedEditors[editorIndex]);
[272] Fix | Delete
}
[273] Fix | Delete
[274] Fix | Delete
window.clearInterval(interval);
[275] Fix | Delete
[276] Fix | Delete
return self.loadedEditors;
[277] Fix | Delete
}
[278] Fix | Delete
},
[279] Fix | Delete
250
[280] Fix | Delete
);
[281] Fix | Delete
};
[282] Fix | Delete
[283] Fix | Delete
if (self.tinymceIsAvailable()) {
[284] Fix | Delete
findEditors();
[285] Fix | Delete
}
[286] Fix | Delete
[287] Fix | Delete
// Add support for the Beaver Builder.
[288] Fix | Delete
if (typeof FLLightbox !== 'undefined') {
[289] Fix | Delete
$.each(FLLightbox._instances, function (index) {
[290] Fix | Delete
FLLightbox._instances[index].on('open', function () {
[291] Fix | Delete
setTimeout(function () {
[292] Fix | Delete
findEditors();
[293] Fix | Delete
}, 500);
[294] Fix | Delete
});
[295] Fix | Delete
[296] Fix | Delete
FLLightbox._instances[index].on('didHideLightbox', function () {
[297] Fix | Delete
setTimeout(function () {
[298] Fix | Delete
findEditors();
[299] Fix | Delete
}, 500);
[300] Fix | Delete
});
[301] Fix | Delete
});
[302] Fix | Delete
}
[303] Fix | Delete
};
[304] Fix | Delete
[305] Fix | Delete
/**
[306] Fix | Delete
* Detects if tinymce object is available
[307] Fix | Delete
* @return Boolean True, if available
[308] Fix | Delete
*/
[309] Fix | Delete
self.tinymceIsAvailable = function () {
[310] Fix | Delete
return typeof window.tinymce === 'object' || typeof window.tinyMCE === 'object';
[311] Fix | Delete
};
[312] Fix | Delete
[313] Fix | Delete
/**
[314] Fix | Delete
* Returns true if the controller panel is active
[315] Fix | Delete
* @return Boolean True, if the controller panel is active
[316] Fix | Delete
*/
[317] Fix | Delete
self.controllerPanelIsActive = function () {
[318] Fix | Delete
return typeof self.activeControllerPanel !== 'undefined' && self.activeControllerPanel !== null;
[319] Fix | Delete
};
[320] Fix | Delete
[321] Fix | Delete
/**
[322] Fix | Delete
* Returns the editor
[323] Fix | Delete
* @return Object The editor
[324] Fix | Delete
*/
[325] Fix | Delete
self.getEditors = function () {
[326] Fix | Delete
if (!window.tinymce || !window.tinymce.editors || window.tinymce.editors.length === 0) {
[327] Fix | Delete
return [];
[328] Fix | Delete
}
[329] Fix | Delete
[330] Fix | Delete
return window.tinymce.editors || [];
[331] Fix | Delete
};
[332] Fix | Delete
[333] Fix | Delete
/**
[334] Fix | Delete
* Parses the content, sending it to the component which will
[335] Fix | Delete
* look for urls to be parsed into embed codes
[336] Fix | Delete
*
[337] Fix | Delete
* @param string content The content
[338] Fix | Delete
* @param function onsuccess The callback called on success
[339] Fix | Delete
* @return void
[340] Fix | Delete
*/
[341] Fix | Delete
self.getParsedContent = function (content, onsuccess) {
[342] Fix | Delete
// Get the parsed content
[343] Fix | Delete
$.ajax({
[344] Fix | Delete
type: 'POST',
[345] Fix | Delete
url: self.params.baseUrl + 'wp-admin/admin-ajax.php',
[346] Fix | Delete
data: {
[347] Fix | Delete
action: 'embedpress_do_ajax_request',
[348] Fix | Delete
subject: content
[349] Fix | Delete
},
[350] Fix | Delete
success: onsuccess,
[351] Fix | Delete
dataType: 'json',
[352] Fix | Delete
async: true
[353] Fix | Delete
});
[354] Fix | Delete
};
[355] Fix | Delete
[356] Fix | Delete
self.addStylesheet = function (url, editorInstance) {
[357] Fix | Delete
var head = editorInstance.getDoc().getElementsByTagName('head')[0];
[358] Fix | Delete
[359] Fix | Delete
var $style = $('<link rel="stylesheet" type="text/css" href="' + url + '">');
[360] Fix | Delete
$style.appendTo(head);
[361] Fix | Delete
};
[362] Fix | Delete
[363] Fix | Delete
self.convertURLSchemeToPattern = function (scheme) {
[364] Fix | Delete
var prefix = '(.*)((?:http|embedpress)s?:\\/\\/(?:www\\.)?',
[365] Fix | Delete
suffix = '[\\/]?)(.*)',
[366] Fix | Delete
pattern;
[367] Fix | Delete
[368] Fix | Delete
scheme = scheme.replace(/\*/g, '[a-zA-Z0-9=&_\\-\\?\\.\\/!\\+%:@,#]+');
[369] Fix | Delete
scheme = scheme.replace(/\./g, '\\.');
[370] Fix | Delete
scheme = scheme.replace(/\//g, '\\/');
[371] Fix | Delete
[372] Fix | Delete
return prefix + scheme + suffix;
[373] Fix | Delete
};
[374] Fix | Delete
[375] Fix | Delete
self.getProvidersURLPatterns = function () {
[376] Fix | Delete
// @todo: Add option to disable/enable the providers
[377] Fix | Delete
var patterns = [];
[378] Fix | Delete
[379] Fix | Delete
self.each($data.urlSchemes, function convertEachURLSchemesToPattern (scheme) {
[380] Fix | Delete
patterns.push(self.convertURLSchemeToPattern(scheme));
[381] Fix | Delete
});
[382] Fix | Delete
[383] Fix | Delete
return patterns;
[384] Fix | Delete
};
[385] Fix | Delete
[386] Fix | Delete
self.addScript = function (source, callback, wrapper, editorInstance) {
[387] Fix | Delete
var doc = editorInstance.getDoc();
[388] Fix | Delete
[389] Fix | Delete
if (typeof wrapper === 'undefined' || !wrapper) {
[390] Fix | Delete
wrapper = $(doc.getElementsByTagName('head')[0]);
[391] Fix | Delete
}
[392] Fix | Delete
[393] Fix | Delete
var $script = $(doc.createElement('script'));
[394] Fix | Delete
$script.attr('async', 1);
[395] Fix | Delete
[396] Fix | Delete
if (typeof callback === 'function') {
[397] Fix | Delete
$script.ready(callback);
[398] Fix | Delete
}
[399] Fix | Delete
[400] Fix | Delete
$script.attr('src', source);
[401] Fix | Delete
[402] Fix | Delete
wrapper.append($script);
[403] Fix | Delete
};
[404] Fix | Delete
[405] Fix | Delete
self.addScriptDeclaration = function (wrapper, declaration, editorInstance) {
[406] Fix | Delete
var doc = editorInstance.getDoc(),
[407] Fix | Delete
$script = $(doc.createElement('script'));
[408] Fix | Delete
[409] Fix | Delete
$(wrapper).append($script);
[410] Fix | Delete
[411] Fix | Delete
$script.text(declaration);
[412] Fix | Delete
};
[413] Fix | Delete
[414] Fix | Delete
self.addURLsPlaceholder = function (node, url, editorInstance) {
[415] Fix | Delete
var uid = self.makeId();
[416] Fix | Delete
[417] Fix | Delete
var wrapperClasses = ['embedpress_wrapper', 'embedpress_placeholder', 'wpview', 'wpview-wrap'];
[418] Fix | Delete
[419] Fix | Delete
var shortcodeAttributes = node.value.getShortcodeAttributes($data.EMBEDPRESS_SHORTCODE);
[420] Fix | Delete
var customAttributes = shortcodeAttributes;
[421] Fix | Delete
[422] Fix | Delete
var customClasses = '';
[423] Fix | Delete
if (!!Object.keys(shortcodeAttributes).length) {
[424] Fix | Delete
var specialAttributes = ['class', 'href', 'data-href'];
[425] Fix | Delete
// Iterates over each attribute of shortcodeAttributes to add the prefix "data-" if missing
[426] Fix | Delete
var dataPrefix = 'data-';
[427] Fix | Delete
var prefixedShortcodeAttributes = [];
[428] Fix | Delete
for (var attr in shortcodeAttributes) {
[429] Fix | Delete
if (specialAttributes.indexOf(attr) === -1) {
[430] Fix | Delete
if (attr.indexOf(dataPrefix) !== 0) {
[431] Fix | Delete
prefixedShortcodeAttributes[dataPrefix + attr] = shortcodeAttributes[attr];
[432] Fix | Delete
} else {
[433] Fix | Delete
prefixedShortcodeAttributes[attr] = shortcodeAttributes[attr];
[434] Fix | Delete
}
[435] Fix | Delete
} else {
[436] Fix | Delete
attr = attr.replace(dataPrefix, '');
[437] Fix | Delete
if (attr === 'class') {
[438] Fix | Delete
wrapperClasses.push(shortcodeAttributes[attr]);
[439] Fix | Delete
}
[440] Fix | Delete
}
[441] Fix | Delete
}
[442] Fix | Delete
[443] Fix | Delete
shortcodeAttributes = prefixedShortcodeAttributes;
[444] Fix | Delete
prefixedShortcodeAttributes = dataPrefix = null;
[445] Fix | Delete
}
[446] Fix | Delete
[447] Fix | Delete
if (('data-width' in shortcodeAttributes || 'data-height' in shortcodeAttributes) && 'data-responsive' in shortcodeAttributes) {
[448] Fix | Delete
shortcodeAttributes['data-responsive'] = 'false';
[449] Fix | Delete
}
[450] Fix | Delete
[451] Fix | Delete
var wrapper = new self.Node('div', 1);
[452] Fix | Delete
var wrapperSettings = {
[453] Fix | Delete
'class': Array.from(new Set(wrapperClasses)).join(' '),
[454] Fix | Delete
'data-url': url,
[455] Fix | Delete
'data-uid': uid,
[456] Fix | Delete
'id': 'embedpress_wrapper_' + uid,
[457] Fix | Delete
'data-loading-text': 'Loading your embed...'
[458] Fix | Delete
};
[459] Fix | Delete
[460] Fix | Delete
wrapperSettings = $.extend({}, wrapperSettings, shortcodeAttributes);
[461] Fix | Delete
[462] Fix | Delete
if (wrapperSettings.class.indexOf('is-loading') === -1) {
[463] Fix | Delete
wrapperSettings.class += ' is-loading';
[464] Fix | Delete
}
[465] Fix | Delete
[466] Fix | Delete
wrapper.attr(wrapperSettings);
[467] Fix | Delete
[468] Fix | Delete
var panel = new self.Node('div', 1);
[469] Fix | Delete
panel.attr({
[470] Fix | Delete
'id': 'embedpress_controller_panel_' + uid,
[471] Fix | Delete
'class': 'embedpress_controller_panel embedpress_ignore_mouseout hidden'
[472] Fix | Delete
});
[473] Fix | Delete
wrapper.append(panel);
[474] Fix | Delete
[475] Fix | Delete
function createGhostNode (htmlTag, content) {
[476] Fix | Delete
htmlTag = htmlTag || 'span';
[477] Fix | Delete
content = content || '&nbsp;';
[478] Fix | Delete
[479] Fix | Delete
var ghostNode = new self.Node(htmlTag, 1);
[480] Fix | Delete
ghostNode.attr({
[481] Fix | Delete
'class': 'hidden'
[482] Fix | Delete
});
[483] Fix | Delete
[484] Fix | Delete
var ghostText = new self.Node('#text', 3);
[485] Fix | Delete
ghostText.value = content;
[486] Fix | Delete
ghostNode.append(ghostText);
[487] Fix | Delete
[488] Fix | Delete
return ghostNode;
[489] Fix | Delete
}
[490] Fix | Delete
[491] Fix | Delete
var editButton = new self.Node('div', 1);
[492] Fix | Delete
editButton.attr({
[493] Fix | Delete
'id': 'embedpress_button_edit_' + uid,
[494] Fix | Delete
'class': 'embedpress_ignore_mouseout embedpress_controller_button'
[495] Fix | Delete
});
[496] Fix | Delete
var editButtonIcon = new self.Node('div', 1);
[497] Fix | Delete
editButtonIcon.attr({
[498] Fix | Delete
'class': 'embedpress-icon-pencil embedpress_ignore_mouseout'
[499] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function