Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(502)

Unified Diff: ios/web/web_state/js/resources/plugin_placeholder.js

Issue 1029983002: Upstream ios/web/ JS files (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ios/web/web_state/js/resources/plugin_placeholder.js
diff --git a/ios/web/web_state/js/resources/plugin_placeholder.js b/ios/web/web_state/js/resources/plugin_placeholder.js
new file mode 100644
index 0000000000000000000000000000000000000000..4a588fdbeaf4f5d20659444a330ad55382e66c35
--- /dev/null
+++ b/ios/web/web_state/js/resources/plugin_placeholder.js
@@ -0,0 +1,199 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// This file adheres to closure-compiler conventions in order to enable
+// compilation with ADVANCED_OPTIMIZATIONS. See http://goo.gl/FwOgy
+//
+// Installs and runs the plugin placeholder function on the |__gCrWeb| object.
+
+/**
+ * Namespace for this file. It depends on |__gCrWeb| having already been
+ * injected.
+ */
+__gCrWeb['plugin'] = {};
+
+/* Beginning of anonymous object. */
+new function() {
+
+ /* Data-URL version of plugin_blocked_android.png. Served this way rather
+ * than with an intercepted URL to avoid messing up https pages.
+ */
+ __gCrWeb['plugin'].imageData_ =
+ '' +
+ 'aklEQVR4Xn2Wz2tcVRTHP/e+O28mMxONJKlF4kIkP4luXFgQuuxCBaG41IWrLupOXLur+A' +
+ 'e4cmV3LiS6qujSLgq2CIKQUqS2YnWsRkzGSTIz7zyHw+EdchnkcOd+7+OeT84578tMwmet' +
+ 'O1fkar1RRNAgUJuqbeEn/0RUcdS6UX7w0X54/93qw4V+m0IReBiizhAYpG52kfrO86+F9/' +
+ 'YXNnukHOTpc5SHgpiOu1cT623FBELeGvgTXfppOAjN3dCKm7GIkWiY4LsBnqBPpGqAgN/z' +
+ 'CDMMBsCWX+pwibd5hzdZZmLNOsxDm8VAzIkt1hX5NLucqgrZm3RlIC/XscKTNlAQpvncMi' +
+ 'tAnEM33D4nqgbcosBSPT3DRTJ3+Cx+4UfV3/CQniMQQ5g2WMJkoGKHNodUCBDpsYEQ2KGm' +
+ 'JBKIFPT4nYckB9ueaPxRscamWczco3qXLcR9wx4ndBsziqFSjaOCAWLm4kj0xhhSMVFli4' +
+ 'opyYuLlJ7s+/xTE6IgcVBthUuW6goHZDiA5IeCAnFEhkKVxxQh+pnoqSeMCEw4Uvt5kEHP' +
+ 'c8IyF3iJ5De1NYSAMOYvOtxgwBqv0wcE5rR4gcQGq9Sc5wt7bq2JtfYtI0Ys8mCmLhFg7q' +
+ 'w6XKRStUHJiMJmpC8vglqypAOU/MwRiw7KYGKqxZSKqE/iTKrQAwGxv5oU4ZbzGHCTf1QN' +
+ 'OTXbQhJ/gbxKjy85IPECHQSQ3EFUfM0+93iZgluM6LuzDUTJOXpc5jcWeDb3DjQrsMhj9t' +
+ 'TdPcAq8mtjjunyFEtN8ohfOWaVZR88Qd2WKK15a5zoRY8ZmRaNIZ/yCZ/P1u0zY+9TASjc' +
+ 'q04YMzBhqAAUBXf5iWcITGdql3aTtpIZVnxGYvSxj1VPXUB0EtHnxBoT6iwgeXEwQfwC69' +
+ 'xmROAcr5DwESxa3XLGW9G9AgPGVKahzzb/UvEcq81PwCl/MyDMrUgxQeMH7tNniQW6nPKA' +
+ 'e5TU3KUFjPmTRxyofUsFeFVQqyENBHDAYyodJhR0CFrnfaYECgvAjdogEwZCVySQaJ8Zeq' +
+ 'AL874rsy+2ofT1ev5fkSdmihwF0jpOra/kskTHkGMckkG9Gg7Xvw9XtifXOy/GEgCr7H/r' +
+ 'yepFOFy5fu1agI9XH71RbRWRrDmHOhrfLYrx9ndv3Wz98R+P7LgG2uyMvgAAAABJRU5Erk' +
+ 'Jggg==';
+
+ /**
+ * Returns the first <embed> child of the given node, if any.
+ * @param {HTMLElement} node The node to check.
+ * @return {HTMLElement} The first <embed> child, or null.
+ * @private
+ */
+ __gCrWeb['plugin'].getEmbedChild_ = function(node) {
+ if (node.hasChildNodes()) {
+ for (var i = 0; i < node.childNodes.length; i++) {
+ if (node.childNodes[i].nodeName === 'EMBED') {
+ return node.childNodes[i];
+ }
+ }
+ }
+ return null;
+ };
+
+ /**
+ * Returns the size for the given plugin element. For the common
+ * pattern of an IE-specific <object> wrapping an all-other-browsers <embed>,
+ * the object doesn't have real style info (most notably size), so this uses
+ * the embed in that case.
+ * @param {HTMLElement} plugin The <object> node to check.
+ * @return {Object} The size (width and height) for the plugin element.
+ * @private
+ */
+ __gCrWeb['plugin'].getPluginSize_ = function(plugin) {
+ var style;
+ // For the common pattern of an IE-specific <object> wrapping an
+ // all-other-browsers <embed>, the object doesn't have real style info
+ // (most notably size), so this uses the embed in that case.
+ var embedChild = __gCrWeb['plugin'].getEmbedChild_(plugin);
+ if (embedChild) {
+ style = window.getComputedStyle(embedChild);
+ } else {
+ style = window.getComputedStyle(plugin);
+ }
+
+ var width = parseFloat(style.width);
+ var height = parseFloat(style.height);
+ if (plugin.tagName === 'APPLET') {
+ // Size computation doesn't always work correctly with applets in
+ // UIWebView, so use the attributes as fallbacks.
+ if (isNaN(width)) {
+ width = parseFloat(plugin.width);
+ }
+ if (isNaN(height)) {
+ height = parseFloat(plugin.height);
+ }
+ }
+
+ return {
+ 'width': width,
+ 'height': height
+ };
+ };
+
+ /**
+ * Checks whether an element is "significant". Whether a plugin is
+ * "significant" is a heuristic that attempts to determine if it's a critical
+ * visual element for the page (i.e., not invisible, or an incidental ad).
+ * @param {HTMLElement} plugin The <object> node to check.
+ * @return {Boolean} Whether the node is significant.
+ * @private
+ */
+ __gCrWeb['plugin'].isSignificantPlugin_ = function(plugin) {
+ var windowWidth = window.innerWidth;
+ var windowHeight = window.innerHeight;
+ var pluginSize = __gCrWeb['plugin'].getPluginSize_(plugin);
+ var pluginWidth = parseFloat(pluginSize.width);
+ var pluginHeight = parseFloat(pluginSize.height);
+ // A plugin must be at least |significantFraction| of one dimension of the
+ // page, and a minimum size in the other dimension (to weed out banners and
+ // tall side ads).
+ var minSize = Math.min(200, windowWidth / 2, windowHeight / 2);
+ var significantFraction = 0.5;
+ return (pluginWidth > windowWidth * significantFraction &&
+ pluginHeight > minSize) ||
+ (pluginHeight > windowHeight * significantFraction &&
+ pluginWidth > minSize);
+ };
+
+ /**
+ * Walks the list of detected plugin elements, adding a placeholder to any
+ * that are "significant" (see above).
+ * @param {string} message The message to show in the placeholder.
+ */
+ __gCrWeb['plugin']['addPluginPlaceholders'] = function(message) {
+ var plugins = __gCrWeb['placeholderTargetPlugins'];
+ for (i = 0; i < plugins.length; i++) {
+ var plugin = plugins[i];
+ if (!__gCrWeb['plugin'].isSignificantPlugin_(plugin)) {
+ continue;
+ }
+
+ var pluginSize = __gCrWeb['plugin'].getPluginSize_(plugin);
+ var widthStyle = pluginSize.width + 'px';
+ var heightStyle = pluginSize.height + 'px';
+
+ // The outer wrapper is a div with relative positioning, as an anchor for
+ // an inner absolute-position element, whose height is based on whether or
+ // not there's an embed. If there is, then it's zero height, to avoid
+ // affecting the layout of the (presumably-full-size) <embed> fallback. If
+ // not, it's full-height to ensure the placeholder takes up the right
+ // amount of space in the page layout. Width is full-width either way, to
+ // avoid being affected by container alignment.
+ var placeholder = document.createElement('div');
+ placeholder.style.width = widthStyle;
+ if (__gCrWeb['plugin'].getEmbedChild_(plugin)) {
+ placeholder.style.height = '0';
+ } else {
+ placeholder.style.height = heightStyle;
+ }
+ placeholder.style.position = 'relative';
+
+ // Inside is a full-plugin-size solid box.
+ var placeholderBox = document.createElement('div');
+ placeholderBox.style.position = 'absolute';
+ placeholderBox.style.boxSizing = 'border-box';
+ placeholderBox.style.width = widthStyle;
+ placeholderBox.style.height = heightStyle;
+ placeholderBox.style.border = '1px solid black';
+ placeholderBox.style.backgroundColor = '#808080';
+ placeholder.appendChild(placeholderBox);
+
+ // Inside that is the plugin placeholder image, centered.
+ var pluginImg = document.createElement('img');
+ var imageSize = 36;
+ pluginImg.width = imageSize;
+ pluginImg.height = imageSize;
+ pluginImg.style.position = 'absolute';
+ // Center vertically and horizontally.
+ var halfSize = imageSize / 2;
+ pluginImg.style.top = '50%';
+ pluginImg.style.marginTop = '-' + halfSize + 'px';
+ pluginImg.style.left = '50%';
+ pluginImg.style.marginLeft = '-' + halfSize + 'px';
+ pluginImg.src = __gCrWeb['plugin'].imageData_;
+ placeholderBox.appendChild(pluginImg);
+
+ // And below that, the message.
+ var label = document.createElement('p');
+ label.style.width = widthStyle;
+ label.style.height = '1.5em';
+ label.style.position = 'absolute';
+ // Position below the image.
+ label.style.top = '50%';
+ label.style.marginTop = imageSize + 'px';
+ // Center horizontally.
+ label.style.textAlign = 'center';
+ label.textContent = message;
+ placeholderBox.appendChild(label);
+
+ plugin.insertBefore(placeholder, plugin.firstChild);
+ }
+ };
+} // End of anonymous object
« no previous file with comments | « ios/web/web_state/js/resources/message_dynamic_wk.js ('k') | ios/web/web_state/js/resources/web_bundle_ui.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698