summaryrefslogtreecommitdiff
path: root/browser
diff options
context:
space:
mode:
authorPale Moon <git-repo@palemoon.org>2015-08-18 08:53:17 +0200
committerPale Moon <git-repo@palemoon.org>2015-08-18 08:53:17 +0200
commit06a219b34d4c19c9368f53dcf97e3414402b75a5 (patch)
tree7191e779b8f090336cc7463d7fda1aca88090445 /browser
parentcc3205520eca5c6e7ef8412ffbe0075f182d521c (diff)
downloadpalemoon-gre-06a219b34d4c19c9368f53dcf97e3414402b75a5.tar.gz
Remove the social API
Diffstat (limited to 'browser')
-rw-r--r--browser/app/profile/firefox.js6
-rw-r--r--browser/base/content/aboutSocialError.xhtml124
-rw-r--r--browser/base/content/browser-context.inc26
-rw-r--r--browser/base/content/browser-menubar.inc47
-rw-r--r--browser/base/content/browser-sets.inc16
-rw-r--r--browser/base/content/browser-social.js1406
-rw-r--r--browser/base/content/browser.css53
-rw-r--r--browser/base/content/browser.js17
-rw-r--r--browser/base/content/browser.xul138
-rw-r--r--browser/base/content/chatWindow.xul109
-rw-r--r--browser/base/content/nsContextMenu.js85
-rw-r--r--browser/base/content/socialchat.xml747
-rw-r--r--browser/base/jar.mn3
-rw-r--r--browser/branding/official/pref/firefox-branding.js2
-rw-r--r--browser/branding/unofficial/pref/firefox-branding.js2
-rw-r--r--browser/components/about/AboutRedirector.cpp3
-rw-r--r--browser/locales/en-US/chrome/browser/browser.dtd40
-rw-r--r--browser/locales/en-US/chrome/browser/browser.properties33
-rw-r--r--browser/modules/Makefile.in1
-rw-r--r--browser/modules/Social.jsm583
-rw-r--r--browser/themes/linux/aboutSocialError.css98
-rw-r--r--browser/themes/linux/browser.css156
-rw-r--r--browser/themes/linux/jar.mn6
-rw-r--r--browser/themes/linux/social/chat-icons.pngbin4407 -> 0 bytes
-rw-r--r--browser/themes/linux/social/services-16.pngbin937 -> 0 bytes
-rw-r--r--browser/themes/linux/social/services-64.pngbin5613 -> 0 bytes
-rw-r--r--browser/themes/linux/social/share-button-active.pngbin1341 -> 0 bytes
-rw-r--r--browser/themes/linux/social/share-button.pngbin1346 -> 0 bytes
-rw-r--r--browser/themes/osx/aboutSocialError.css98
-rw-r--r--browser/themes/osx/browser.css250
-rw-r--r--browser/themes/osx/jar.mn6
-rw-r--r--browser/themes/osx/social/chat-icons.pngbin4407 -> 0 bytes
-rw-r--r--browser/themes/osx/social/services-16.pngbin937 -> 0 bytes
-rw-r--r--browser/themes/osx/social/services-64.pngbin5613 -> 0 bytes
-rw-r--r--browser/themes/osx/social/share-button-active.pngbin1469 -> 0 bytes
-rw-r--r--browser/themes/osx/social/share-button.pngbin1437 -> 0 bytes
-rw-r--r--browser/themes/shared/social/chat.inc.css239
-rw-r--r--browser/themes/windows/aboutSocialError.css98
-rw-r--r--browser/themes/windows/browser.css251
-rw-r--r--browser/themes/windows/jar.mn12
-rw-r--r--browser/themes/windows/social/chat-icons.pngbin4407 -> 0 bytes
-rw-r--r--browser/themes/windows/social/services-16.pngbin937 -> 0 bytes
-rw-r--r--browser/themes/windows/social/services-64.pngbin5613 -> 0 bytes
-rw-r--r--browser/themes/windows/social/share-button-active.pngbin1469 -> 0 bytes
-rw-r--r--browser/themes/windows/social/share-button.pngbin1437 -> 0 bytes
45 files changed, 14 insertions, 4641 deletions
diff --git a/browser/app/profile/firefox.js b/browser/app/profile/firefox.js
index 35cf32b2a..21bfcb03a 100644
--- a/browser/app/profile/firefox.js
+++ b/browser/app/profile/firefox.js
@@ -1226,12 +1226,6 @@ pref("pdfjs.previousHandler.alwaysAskBeforeHandling", false);
// (This is intentionally on the high side; see bug 746055.)
pref("image.mem.max_decoded_image_kb", 256000);
-// Default social providers
-pref("social.manifest.facebook", "{\"origin\":\"https://www.facebook.com\",\"name\":\"Facebook Messenger\",\"workerURL\":\"https://www.facebook.com/desktop/fbdesktop2/socialfox/fbworker.js.php\",\"shareURL\":\"https://www.facebook.com/sharer/sharer.php?u=%{url}\",\"iconURL\":\"%2F9hAAAAX0lEQVQ4jWP4%2F%2F8%2FAyUYTFhHzjgDxP9JxGeQDSBVMxgTbUBCxer%2Fr999%2BQ8DJBuArJksA9A10s8AXIBoA0B%2BR%2FY%2FjD%2BEwoBoA1yT5v3PbdmCE8MAshhID%2FUMoDgzUYIBj0Cgi7ar4coAAAAASUVORK5CYII%3D\",\"sidebarURL\":\"https://www.facebook.com/desktop/fbdesktop2/?socialfox=true\",\"icon32URL\":\"\", \"icon64URL\":\"\", \"description\":\"Keep up with friends wherever you go on the web.\",\"author\":\"Facebook\",\"homepageURL\":\"https://www.facebook.com/about/messenger-for-firefox\",\"builtin\":\"true\"}");
-
-pref("social.sidebar.open", true);
-pref("social.sidebar.unload_timeout_ms", 10000);
-
pref("dom.identity.enabled", false);
// Turn on the CSP 1.0 parser for Content Security Policy headers
diff --git a/browser/base/content/aboutSocialError.xhtml b/browser/base/content/aboutSocialError.xhtml
deleted file mode 100644
index 6bef2d7bd..000000000
--- a/browser/base/content/aboutSocialError.xhtml
+++ /dev/null
@@ -1,124 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-
-<!-- This Source Code Form is subject to the terms of the Mozilla Public
- - License, v. 2.0. If a copy of the MPL was not distributed with this
- - file, You can obtain one at http://mozilla.org/MPL/2.0/. -->
-
-<!DOCTYPE html [
- <!ENTITY % htmlDTD
- PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
- "DTD/xhtml1-strict.dtd">
- %htmlDTD;
- <!ENTITY % netErrorDTD SYSTEM "chrome://global/locale/netError.dtd">
- %netErrorDTD;
-]>
-
-<html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <title>&loadError.label;</title>
- <link rel="stylesheet" type="text/css" media="all"
- href="chrome://browser/skin/aboutSocialError.css"/>
- </head>
-
- <body>
- <div id="error-box">
- <p id="main-error-msg"></p>
- <p id="helper-error-msg"></p>
- </div>
- <div id="button-box">
- <button id="btnTryAgain" onclick="tryAgainButton()"/>
- <button id="btnCloseSidebar" onclick="closeSidebarButton()"/>
- </div>
- </body>
-
- <script type="text/javascript;version=1.8"><![CDATA[
- const Cu = Components.utils;
-
- Cu.import("resource://gre/modules/Services.jsm");
- Cu.import("resource:///modules/Social.jsm");
-
- let config = {
- tryAgainCallback: reloadProvider
- }
-
- function parseQueryString() {
- let url = document.documentURI;
- let queryString = url.replace(/^about:socialerror\??/, "");
-
- let modeMatch = queryString.match(/mode=([^&]+)/);
- let mode = modeMatch && modeMatch[1] ? modeMatch[1] : "";
- let originMatch = queryString.match(/origin=([^&]+)/);
- config.origin = originMatch && originMatch[1] ? decodeURIComponent(originMatch[1]) : "";
-
- switch (mode) {
- case "compactInfo":
- document.getElementById("btnTryAgain").style.display = 'none';
- document.getElementById("btnCloseSidebar").style.display = 'none';
- break;
- case "tryAgainOnly":
- document.getElementById("btnCloseSidebar").style.display = 'none';
- //intentional fall-through
- case "tryAgain":
- let urlMatch = queryString.match(/url=([^&]+)/);
- let encodedURL = urlMatch && urlMatch[1] ? urlMatch[1] : "";
- let url = decodeURIComponent(encodedURL);
-
- config.tryAgainCallback = loadQueryURL;
- config.queryURL = url;
- break;
- case "workerFailure":
- config.tryAgainCallback = reloadProvider;
- break;
- default:
- break;
- }
- }
-
- function setUpStrings() {
- let brandBundle = Services.strings.createBundle("chrome://branding/locale/brand.properties");
- let browserBundle = Services.strings.createBundle("chrome://browser/locale/browser.properties");
-
- let productName = brandBundle.GetStringFromName("brandShortName");
- let provider = Social && Social.provider;
- if (config.origin) {
- provider = Social && Social._getProviderFromOrigin(config.origin);
- }
- let providerName = provider && provider.name;
-
- // Sets up the error message
- let msg = browserBundle.formatStringFromName("social.error.message", [productName, providerName], 2);
- document.getElementById("main-error-msg").textContent = msg;
-
- // Sets up the buttons' labels and accesskeys
- let btnTryAgain = document.getElementById("btnTryAgain");
- btnTryAgain.textContent = browserBundle.GetStringFromName("social.error.tryAgain.label");
- btnTryAgain.accessKey = browserBundle.GetStringFromName("social.error.tryAgain.accesskey");
-
- let btnCloseSidebar = document.getElementById("btnCloseSidebar");
- btnCloseSidebar.textContent = browserBundle.GetStringFromName("social.error.closeSidebar.label");
- btnCloseSidebar.accessKey = browserBundle.GetStringFromName("social.error.closeSidebar.accesskey");
- }
-
- function closeSidebarButton() {
- Social.toggleSidebar();
- }
-
- function tryAgainButton() {
- config.tryAgainCallback();
- }
-
- function loadQueryURL() {
- window.location.href = config.queryURL;
- }
-
- function reloadProvider() {
- Social.enabled = false;
- Services.tm.mainThread.dispatch(function() {
- Social.enabled = true;
- }, Components.interfaces.nsIThread.DISPATCH_NORMAL);
- }
-
- parseQueryString();
- setUpStrings();
- ]]></script>
-</html>
diff --git a/browser/base/content/browser-context.inc b/browser/base/content/browser-context.inc
index 0c2f058ca..b9314a823 100644
--- a/browser/base/content/browser-context.inc
+++ b/browser/base/content/browser-context.inc
@@ -37,13 +37,6 @@
label="&bookmarkThisLinkCmd.label;"
accesskey="&bookmarkThisLinkCmd.accesskey;"
oncommand="gContextMenu.bookmarkLink();"/>
- <menuitem id="context-marklink"
- accesskey="&social.marklink.accesskey;"
- oncommand="gContextMenu.markLink();"/>
- <menuitem id="context-sharelink"
- label="&shareLinkCmd.label;"
- accesskey="&shareLinkCmd.accesskey;"
- oncommand="gContextMenu.shareLink();"/>
<menuitem id="context-savelink"
label="&saveLinkCmd.label;"
accesskey="&saveLinkCmd.accesskey;"
@@ -168,10 +161,6 @@
label="&saveImageCmd.label;"
accesskey="&saveImageCmd.accesskey;"
oncommand="gContextMenu.saveMedia();"/>
- <menuitem id="context-shareimage"
- label="&shareImageCmd.label;"
- accesskey="&shareImageCmd.accesskey;"
- oncommand="gContextMenu.shareImage();"/>
<menuitem id="context-sendimage"
label="&emailImageCmd.label;"
accesskey="&emailImageCmd.accesskey;"
@@ -188,10 +177,6 @@
label="&saveVideoCmd.label;"
accesskey="&saveVideoCmd.accesskey;"
oncommand="gContextMenu.saveMedia();"/>
- <menuitem id="context-sharevideo"
- label="&shareVideoCmd.label;"
- accesskey="&shareVideoCmd.accesskey;"
- oncommand="gContextMenu.shareVideo();"/>
<menuitem id="context-saveaudio"
label="&saveAudioCmd.label;"
accesskey="&saveAudioCmd.accesskey;"
@@ -241,13 +226,6 @@
label="&bookmarkPageCmd2.label;"
accesskey="&bookmarkPageCmd2.accesskey;"
oncommand="gContextMenu.bookmarkThisPage();"/>
- <menuitem id="context-markpage"
- accesskey="&social.markpage.accesskey;"
- command="Social:TogglePageMark"/>
- <menuitem id="context-sharepage"
- label="&sharePageCmd.label;"
- accesskey="&sharePageCmd.accesskey;"
- oncommand="SocialShare.sharePage();"/>
<menuitem id="context-savepage"
label="&savePageCmd.label;"
accesskey="&savePageCmd.accesskey2;"
@@ -295,10 +273,6 @@
oncommand="AddKeywordForSearchField();"/>
<menuitem id="context-searchselect"
oncommand="BrowserSearch.loadSearchFromContext(getBrowserSelection());"/>
- <menuitem id="context-shareselect"
- label="&shareSelectCmd.label;"
- accesskey="&shareSelectCmd.accesskey;"
- oncommand="gContextMenu.shareSelect(getBrowserSelection());"/>
<menuseparator id="frame-sep"/>
<menu id="frame" label="&thisFrameMenu.label;" accesskey="&thisFrameMenu.accesskey;">
<menupopup>
diff --git a/browser/base/content/browser-menubar.inc b/browser/base/content/browser-menubar.inc
index 6d52f12d3..081ed8d65 100644
--- a/browser/base/content/browser-menubar.inc
+++ b/browser/base/content/browser-menubar.inc
@@ -207,10 +207,6 @@
key="key_gotoHistory"
observes="viewHistorySidebar"
label="&historyButton.label;"/>
- <menuitem id="menu_socialSidebar"
- type="checkbox"
- autocheck="false"
- command="Social:ToggleSidebar"/>
</menupopup>
</menu>
<menuseparator/>
@@ -506,49 +502,6 @@
accesskey="&addons.accesskey;"
key="key_openAddons"
command="Tools:Addons"/>
- <menu id="menu_socialAmbientMenu"
- observes="socialActiveBroadcaster">
- <menupopup id="menu_social-statusarea-popup">
- <menuitem class="social-statusarea-user menuitem-iconic" pack="start" align="center"
- observes="socialBroadcaster_userDetails"
- oncommand="SocialUI.showProfile(); document.getElementById('social-statusarea-popup').hidePopup();">
- <image class="social-statusarea-user-portrait"
- observes="socialBroadcaster_userDetails"/>
- <vbox>
- <label class="social-statusarea-loggedInStatus"
- observes="socialBroadcaster_userDetails"/>
- </vbox>
- </menuitem>
-#ifndef XP_WIN
- <menuseparator class="social-statusarea-separator"/>
-#endif
- <menuseparator id="socialAmbientMenuSeparator"
- hidden="true"/>
- <menuitem class="social-toggle-sidebar-menuitem"
- type="checkbox"
- autocheck="false"
- command="Social:ToggleSidebar"
- label="&social.toggleSidebar.label;"
- accesskey="&social.toggleSidebar.accesskey;"/>
- <menuitem class="social-toggle-notifications-menuitem"
- type="checkbox"
- autocheck="false"
- command="Social:ToggleNotifications"
- label="&social.toggleNotifications.label;"
- accesskey="&social.toggleNotifications.accesskey;"/>
- <menuitem id="menu_focusChatBar"
- label="&social.chatBar.label;"
- accesskey="&social.chatBar.accesskey;"
- key="focusChatBar"
- command="Social:FocusChat"
- class="show-only-for-keyboard"/>
- <menuitem class="social-toggle-menuitem" command="Social:Toggle"/>
- <menuseparator class="social-statusarea-separator"/>
- <menuseparator class="social-provider-menu" hidden="true"/>
- <menuitem class="social-addons-menuitem" command="Social:Addons"
- label="&social.addons.label;"/>
- </menupopup>
- </menu>
#ifdef MOZ_SERVICES_SYNC
<!-- only one of sync-setup or sync-menu will be showing at once -->
<menuitem id="sync-setup"
diff --git a/browser/base/content/browser-sets.inc b/browser/base/content/browser-sets.inc
index c017c669b..b8a639fe6 100644
--- a/browser/base/content/browser-sets.inc
+++ b/browser/base/content/browser-sets.inc
@@ -112,13 +112,6 @@
<command id="History:UndoCloseTab" oncommand="undoCloseTab();"/>
<command id="History:UndoCloseWindow" oncommand="undoCloseWindow();"/>
<command id="Browser:ToggleAddonBar" oncommand="toggleAddonBar();"/>
- <command id="Social:TogglePageMark" oncommand="SocialMark.togglePageMark();" disabled="true"/>
- <command id="Social:SharePage" oncommand="SocialShare.sharePage();" disabled="true"/>
- <command id="Social:ToggleSidebar" oncommand="Social.toggleSidebar();"/>
- <command id="Social:ToggleNotifications" oncommand="Social.toggleNotifications();" hidden="true"/>
- <command id="Social:FocusChat" oncommand="SocialChatBar.focus();" hidden="true" disabled="true"/>
- <command id="Social:Toggle" oncommand="Social.toggle();" hidden="true"/>
- <command id="Social:Addons" oncommand="BrowserOpenAddonsMgr('addons://list/service');"/>
</commandset>
<commandset id="placesCommands">
@@ -171,8 +164,6 @@
<broadcaster id="sync-syncnow-state"/>
#endif
<broadcaster id="workOfflineMenuitemState"/>
- <broadcaster id="socialSidebarBroadcaster" hidden="true"/>
- <broadcaster id="socialActiveBroadcaster" hidden="true"/>
#ifdef MOZ_DEVTOOLS
<!-- DevTools broadcasters -->
@@ -218,10 +209,6 @@
label="&devtoolsConnect.label;"
command="Tools:DevToolsConnect"/>
#endif
-
- <!-- SocialAPI broadcasters -->
- <broadcaster id="socialBroadcaster_userDetails"
- notLoggedInLabel="&social.notLoggedIn.label;"/>
</broadcasterset>
<keyset id="mainKeyset">
@@ -361,9 +348,6 @@
<key id="viewBookmarksSidebarWinKb" key="&bookmarksWinCmd.commandkey;" command="viewBookmarksSidebar" modifiers="accel"/>
#endif
- <key id="markPage" key="&markPageCmd.commandkey;" command="Social:TogglePageMark" modifiers="accel,shift"/>
- <key id="focusChatBar" key="&social.chatBar.commandkey;" command="Social:FocusChat" modifiers="accel,shift"/>
-
<key id="key_stop" keycode="VK_ESCAPE" command="Browser:Stop"/>
#ifdef XP_MACOSX
diff --git a/browser/base/content/browser-social.js b/browser/base/content/browser-social.js
deleted file mode 100644
index 7a0ab726c..000000000
--- a/browser/base/content/browser-social.js
+++ /dev/null
@@ -1,1406 +0,0 @@
-// This Source Code Form is subject to the terms of the Mozilla Public
-// License, v. 2.0. If a copy of the MPL was not distributed with this
-// file, You can obtain one at http://mozilla.org/MPL/2.0/.
-
-// the "exported" symbols
-let SocialUI,
- SocialChatBar,
- SocialFlyout,
- SocialMark,
- SocialShare,
- SocialMenu,
- SocialToolbar,
- SocialSidebar;
-
-(function() {
-
-// The minimum sizes for the auto-resize panel code.
-const PANEL_MIN_HEIGHT = 100;
-const PANEL_MIN_WIDTH = 330;
-
-XPCOMUtils.defineLazyModuleGetter(this, "SharedFrame",
- "resource:///modules/SharedFrame.jsm");
-
-XPCOMUtils.defineLazyGetter(this, "OpenGraphBuilder", function() {
- let tmp = {};
- Cu.import("resource:///modules/Social.jsm", tmp);
- return tmp.OpenGraphBuilder;
-});
-
-SocialUI = {
- // Called on delayed startup to initialize the UI
- init: function SocialUI_init() {
- Services.obs.addObserver(this, "social:ambient-notification-changed", false);
- Services.obs.addObserver(this, "social:profile-changed", false);
- Services.obs.addObserver(this, "social:page-mark-config", false);
- Services.obs.addObserver(this, "social:frameworker-error", false);
- Services.obs.addObserver(this, "social:provider-set", false);
- Services.obs.addObserver(this, "social:providers-changed", false);
-
- Services.prefs.addObserver("social.sidebar.open", this, false);
- Services.prefs.addObserver("social.toast-notifications.enabled", this, false);
-
- gBrowser.addEventListener("ActivateSocialFeature", this._activationEventHandler.bind(this), true, true);
-
- SocialChatBar.init();
- SocialMark.init();
- SocialShare.init();
- SocialMenu.init();
- SocialToolbar.init();
- SocialSidebar.init();
-
- if (!Social.initialized) {
- Social.init();
- } else {
- // social was previously initialized, so it's not going to notify us of
- // anything, so handle that now.
- this.observe(null, "social:providers-changed", null);
- this.observe(null, "social:provider-set", Social.provider ? Social.provider.origin : null);
- }
- },
-
- // Called on window unload
- uninit: function SocialUI_uninit() {
- Services.obs.removeObserver(this, "social:ambient-notification-changed");
- Services.obs.removeObserver(this, "social:profile-changed");
- Services.obs.removeObserver(this, "social:page-mark-config");
- Services.obs.removeObserver(this, "social:frameworker-error");
- Services.obs.removeObserver(this, "social:provider-set");
- Services.obs.removeObserver(this, "social:providers-changed");
-
- Services.prefs.removeObserver("social.sidebar.open", this);
- Services.prefs.removeObserver("social.toast-notifications.enabled", this);
- },
-
- _matchesCurrentProvider: function (origin) {
- return Social.provider && Social.provider.origin == origin;
- },
-
- observe: function SocialUI_observe(subject, topic, data) {
- // Exceptions here sometimes don't get reported properly, report them
- // manually :(
- try {
- switch (topic) {
- case "social:provider-set":
- // Social.provider has changed (possibly to null), update any state
- // which depends on it.
- this._updateActiveUI();
- this._updateMenuItems();
-
- SocialFlyout.unload();
- SocialChatBar.update();
- SocialShare.update();
- SocialSidebar.update();
- SocialMark.update();
- SocialToolbar.update();
- SocialMenu.populate();
- break;
- case "social:providers-changed":
- // the list of providers changed - this may impact the "active" UI.
- this._updateActiveUI();
- // and the multi-provider menu
- SocialToolbar.populateProviderMenus();
- SocialShare.populateProviderMenu();
- break;
-
- // Provider-specific notifications
- case "social:ambient-notification-changed":
- if (this._matchesCurrentProvider(data)) {
- SocialToolbar.updateButton();
- SocialMenu.populate();
- }
- break;
- case "social:profile-changed":
- if (this._matchesCurrentProvider(data)) {
- SocialToolbar.updateProvider();
- SocialMark.update();
- SocialChatBar.update();
- }
- break;
- case "social:page-mark-config":
- if (this._matchesCurrentProvider(data)) {
- SocialMark.updateMarkState();
- }
- break;
- case "social:frameworker-error":
- if (this.enabled && Social.provider.origin == data) {
- SocialSidebar.setSidebarErrorMessage();
- }
- break;
-
- case "nsPref:changed":
- if (data == "social.sidebar.open") {
- SocialSidebar.update();
- } else if (data == "social.toast-notifications.enabled") {
- SocialToolbar.updateButton();
- }
- break;
- }
- } catch (e) {
- Components.utils.reportError(e + "\n" + e.stack);
- throw e;
- }
- },
-
- nonBrowserWindowInit: function SocialUI_nonBrowserInit() {
- // Disable the social menu item in non-browser windows
- document.getElementById("menu_socialAmbientMenu").hidden = true;
- },
-
- // Miscellaneous helpers
- showProfile: function SocialUI_showProfile() {
- if (Social.haveLoggedInUser())
- openUILinkIn(Social.provider.profile.profileURL, "tab");
- else {
- // XXX Bug 789585 will implement an API for provider-specified login pages.
- openUILinkIn(Social.provider.origin, "tab");
- }
- },
-
- _updateActiveUI: function SocialUI_updateActiveUI() {
- // The "active" UI isn't dependent on there being a provider, just on
- // social being "active" (but also chromeless/PB)
- let enabled = Social.providers.length > 0 && !this._chromeless &&
- !PrivateBrowsingUtils.isWindowPrivate(window);
- let broadcaster = document.getElementById("socialActiveBroadcaster");
- broadcaster.hidden = !enabled;
-
- let toggleCommand = document.getElementById("Social:Toggle");
- toggleCommand.setAttribute("hidden", enabled ? "false" : "true");
-
- if (enabled) {
- // enabled == true means we at least have a defaultProvider
- let provider = Social.provider || Social.defaultProvider;
- // We only need to update the command itself - all our menu items use it.
- let label = gNavigatorBundle.getFormattedString(Social.provider ?
- "social.turnOff.label" :
- "social.turnOn.label",
- [provider.name]);
- let accesskey = gNavigatorBundle.getString(Social.provider ?
- "social.turnOff.accesskey" :
- "social.turnOn.accesskey");
- toggleCommand.setAttribute("label", label);
- toggleCommand.setAttribute("accesskey", accesskey);
- }
- },
-
- _updateMenuItems: function () {
- let provider = Social.provider || Social.defaultProvider;
- if (!provider)
- return;
- // The View->Sidebar and Menubar->Tools menu.
- for (let id of ["menu_socialSidebar", "menu_socialAmbientMenu"])
- document.getElementById(id).setAttribute("label", provider.name);
- },
-
- // This handles "ActivateSocialFeature" events fired against content documents
- // in this window.
- _activationEventHandler: function SocialUI_activationHandler(e) {
- let targetDoc;
- let node;
- if (e.target instanceof HTMLDocument) {
- // version 0 support
- targetDoc = e.target;
- node = targetDoc.documentElement
- } else {
- targetDoc = e.target.ownerDocument;
- node = e.target;
- }
- if (!(targetDoc instanceof HTMLDocument))
- return;
-
- // Ignore events fired in background tabs or iframes
- if (targetDoc.defaultView != content)
- return;
-
- // If we are in PB mode, we silently do nothing (bug 829404 exists to
- // do something sensible here...)
- if (PrivateBrowsingUtils.isWindowPrivate(window))
- return;
-
- // If the last event was received < 1s ago, ignore this one
- let now = Date.now();
- if (now - Social.lastEventReceived < 1000)
- return;
- Social.lastEventReceived = now;
-
- // We only want to activate if it is as a result of user input.
- let dwu = window.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIDOMWindowUtils);
- if (!dwu.isHandlingUserInput) {
- Cu.reportError("attempt to activate provider without user input from " + targetDoc.nodePrincipal.origin);
- return;
- }
-
- let data = node.getAttribute("data-service");
- if (data) {
- try {
- data = JSON.parse(data);
- } catch(e) {
- Cu.reportError("Social Service manifest parse error: "+e);
- return;
- }
- }
- Social.installProvider(targetDoc, data, function(manifest) {
- this.doActivation(manifest.origin);
- }.bind(this));
- },
-
- doActivation: function SocialUI_doActivation(origin) {
- // Keep track of the old provider in case of undo
- let oldOrigin = Social.provider ? Social.provider.origin : "";
-
- // Enable the social functionality, and indicate that it was activated
- Social.activateFromOrigin(origin, function(provider) {
- // Provider to activate may not have been found
- if (!provider)
- return;
-
- // Show a warning, allow undoing the activation
- let description = document.getElementById("social-activation-message");
- let labels = description.getElementsByTagName("label");
- let uri = Services.io.newURI(provider.origin, null, null)
- labels[0].setAttribute("value", uri.host);
- labels[1].setAttribute("onclick", "BrowserOpenAddonsMgr('addons://list/service'); SocialUI.activationPanel.hidePopup();")
-
- let icon = document.getElementById("social-activation-icon");
- if (provider.icon64URL || provider.icon32URL) {
- icon.setAttribute('src', provider.icon64URL || provider.icon32URL);
- icon.hidden = false;
- } else {
- icon.removeAttribute('src');
- icon.hidden = true;
- }
-
- let notificationPanel = SocialUI.activationPanel;
- // Set the origin being activated and the previously active one, to allow undo
- notificationPanel.setAttribute("origin", provider.origin);
- notificationPanel.setAttribute("oldorigin", oldOrigin);
-
- // Show the panel
- notificationPanel.hidden = false;
- setTimeout(function () {
- notificationPanel.openPopup(SocialToolbar.button, "bottomcenter topright");
- }, 0);
- });
- },
-
- undoActivation: function SocialUI_undoActivation() {
- let origin = this.activationPanel.getAttribute("origin");
- let oldOrigin = this.activationPanel.getAttribute("oldorigin");
- Social.deactivateFromOrigin(origin, oldOrigin);
- this.activationPanel.hidePopup();
- Social.uninstallProvider(origin);
- },
-
- showLearnMore: function() {
- this.activationPanel.hidePopup();
- let url = Services.urlFormatter.formatURLPref("app.support.baseURL") + "social-api";
- openUILinkIn(url, "tab");
- },
-
- get activationPanel() {
- return document.getElementById("socialActivatedNotification");
- },
-
- closeSocialPanelForLinkTraversal: function (target, linkNode) {
- // No need to close the panel if this traversal was not retargeted
- if (target == "" || target == "_self")
- return;
-
- // Check to see whether this link traversal was in a social panel
- let win = linkNode.ownerDocument.defaultView;
- let container = win.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIWebNavigation)
- .QueryInterface(Ci.nsIDocShell)
- .chromeEventHandler;
- let containerParent = container.parentNode;
- if (containerParent.classList.contains("social-panel") &&
- containerParent instanceof Ci.nsIDOMXULPopupElement) {
- // allow the link traversal to finish before closing the panel
- setTimeout(() => {
- containerParent.hidePopup();
- }, 0);
- }
- },
-
- get _chromeless() {
- // Is this a popup window that doesn't want chrome shown?
- let docElem = document.documentElement;
- // extrachrome is not restored during session restore, so we need
- // to check for the toolbar as well.
- let chromeless = docElem.getAttribute("chromehidden").contains("extrachrome") ||
- docElem.getAttribute('chromehidden').contains("toolbar");
- // This property is "fixed" for a window, so avoid doing the check above
- // multiple times...
- delete this._chromeless;
- this._chromeless = chromeless;
- return chromeless;
- },
-
- get enabled() {
- // Returns whether social is enabled *for this window*.
- if (this._chromeless || PrivateBrowsingUtils.isWindowPrivate(window))
- return false;
- return !!Social.provider;
- },
-
-}
-
-SocialChatBar = {
- init: function() {
- },
- get chatbar() {
- return document.getElementById("pinnedchats");
- },
- // Whether the chatbar is available for this window. Note that in full-screen
- // mode chats are available, but not shown.
- get isAvailable() {
- return SocialUI.enabled && Social.haveLoggedInUser();
- },
- // Does this chatbar have any chats (whether minimized, collapsed or normal)
- get hasChats() {
- return !!this.chatbar.firstElementChild;
- },
- openChat: function(aProvider, aURL, aCallback, aMode) {
- if (!this.isAvailable)
- return false;
- this.chatbar.openChat(aProvider, aURL, aCallback, aMode);
- // We only want to focus the chat if it is as a result of user input.
- let dwu = window.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIDOMWindowUtils);
- if (dwu.isHandlingUserInput)
- this.chatbar.focus();
- return true;
- },
- update: function() {
- let command = document.getElementById("Social:FocusChat");
- if (!this.isAvailable) {
- this.chatbar.removeAll();
- this.chatbar.hidden = command.hidden = true;
- } else {
- this.chatbar.hidden = command.hidden = false;
- }
- command.setAttribute("disabled", command.hidden ? "true" : "false");
- },
- focus: function SocialChatBar_focus() {
- this.chatbar.focus();
- }
-}
-
-function sizeSocialPanelToContent(panel, iframe) {
- // FIXME: bug 764787: Maybe we can use nsIDOMWindowUtils.getRootBounds() here?
- let doc = iframe.contentDocument;
- if (!doc || !doc.body) {
- return;
- }
- // We need an element to use for sizing our panel. See if the body defines
- // an id for that element, otherwise use the body itself.
- let body = doc.body;
- let bodyId = body.getAttribute("contentid");
- if (bodyId) {
- body = doc.getElementById(bodyId) || doc.body;
- }
- // offsetHeight/Width don't include margins, so account for that.
- let cs = doc.defaultView.getComputedStyle(body);
- let computedHeight = parseInt(cs.marginTop) + body.offsetHeight + parseInt(cs.marginBottom);
- let height = Math.max(computedHeight, PANEL_MIN_HEIGHT);
- let computedWidth = parseInt(cs.marginLeft) + body.offsetWidth + parseInt(cs.marginRight);
- let width = Math.max(computedWidth, PANEL_MIN_WIDTH);
- iframe.style.width = width + "px";
- iframe.style.height = height + "px";
- // since we do not use panel.sizeTo, we need to adjust the arrow ourselves
- if (panel.state == "open")
- panel.adjustArrowPosition();
-}
-
-function DynamicResizeWatcher() {
- this._mutationObserver = null;
-}
-
-DynamicResizeWatcher.prototype = {
- start: function DynamicResizeWatcher_start(panel, iframe) {
- this.stop(); // just in case...
- let doc = iframe.contentDocument;
- this._mutationObserver = new iframe.contentWindow.MutationObserver(function(mutations) {
- sizeSocialPanelToContent(panel, iframe);
- });
- // Observe anything that causes the size to change.
- let config = {attributes: true, characterData: true, childList: true, subtree: true};
- this._mutationObserver.observe(doc, config);
- // and since this may be setup after the load event has fired we do an
- // initial resize now.
- sizeSocialPanelToContent(panel, iframe);
- },
- stop: function DynamicResizeWatcher_stop() {
- if (this._mutationObserver) {
- try {
- this._mutationObserver.disconnect();
- } catch (ex) {
- // may get "TypeError: can't access dead object" which seems strange,
- // but doesn't seem to indicate a real problem, so ignore it...
- }
- this._mutationObserver = null;
- }
- }
-}
-
-SocialFlyout = {
- get panel() {
- return document.getElementById("social-flyout-panel");
- },
-
- get iframe() {
- if (!this.panel.firstChild)
- this._createFrame();
- return this.panel.firstChild;
- },
-
- dispatchPanelEvent: function(name) {
- let doc = this.iframe.contentDocument;
- let evt = doc.createEvent("CustomEvent");
- evt.initCustomEvent(name, true, true, {});
- doc.documentElement.dispatchEvent(evt);
- },
-
- _createFrame: function() {
- let panel = this.panel;
- if (!SocialUI.enabled || panel.firstChild)
- return;
- // create and initialize the panel for this window
- let iframe = document.createElement("iframe");
- iframe.setAttribute("type", "content");
- iframe.setAttribute("class", "social-panel-frame");
- iframe.setAttribute("flex", "1");
- iframe.setAttribute("tooltip", "aHTMLTooltip");
- iframe.setAttribute("origin", Social.provider.origin);
- panel.appendChild(iframe);
- },
-
- setFlyoutErrorMessage: function SF_setFlyoutErrorMessage() {
- this.iframe.removeAttribute("src");
- this.iframe.webNavigation.loadURI("about:socialerror?mode=compactInfo", null, null, null, null);
- sizeSocialPanelToContent(this.panel, this.iframe);
- },
-
- unload: function() {
- let panel = this.panel;
- panel.hidePopup();
- if (!panel.firstChild)
- return
- let iframe = panel.firstChild;
- if (iframe.socialErrorListener)
- iframe.socialErrorListener.remove();
- panel.removeChild(iframe);
- },
-
- onShown: function(aEvent) {
- let panel = this.panel;
- let iframe = this.iframe;
- this._dynamicResizer = new DynamicResizeWatcher();
- iframe.docShell.isActive = true;
- iframe.docShell.isAppTab = true;
- if (iframe.contentDocument.readyState == "complete") {
- this._dynamicResizer.start(panel, iframe);
- this.dispatchPanelEvent("socialFrameShow");
- } else {
- // first time load, wait for load and dispatch after load
- iframe.addEventListener("load", function panelBrowserOnload(e) {
- iframe.removeEventListener("load", panelBrowserOnload, true);
- setTimeout(function() {
- if (SocialFlyout._dynamicResizer) { // may go null if hidden quickly
- SocialFlyout._dynamicResizer.start(panel, iframe);
- SocialFlyout.dispatchPanelEvent("socialFrameShow");
- }
- }, 0);
- }, true);
- }
- },
-
- onHidden: function(aEvent) {
- this._dynamicResizer.stop();
- this._dynamicResizer = null;
- this.iframe.docShell.isActive = false;
- this.dispatchPanelEvent("socialFrameHide");
- },
-
- load: function(aURL, cb) {
- if (!Social.provider)
- return;
-
- this.panel.hidden = false;
- let iframe = this.iframe;
- // same url with only ref difference does not cause a new load, so we
- // want to go right to the callback
- let src = iframe.contentDocument && iframe.contentDocument.documentURIObject;
- if (!src || !src.equalsExceptRef(Services.io.newURI(aURL, null, null))) {
- iframe.addEventListener("load", function documentLoaded() {
- iframe.removeEventListener("load", documentLoaded, true);
- cb();
- }, true);
- // Force a layout flush by calling .clientTop so
- // that the docShell of this frame is created
- iframe.clientTop;
- Social.setErrorListener(iframe, SocialFlyout.setFlyoutErrorMessage.bind(SocialFlyout))
- iframe.setAttribute("src", aURL);
- } else {
- // we still need to set the src to trigger the contents hashchange event
- // for ref changes
- iframe.setAttribute("src", aURL);
- cb();
- }
- },
-
- open: function(aURL, yOffset, aCallback) {
- // Hide any other social panels that may be open.
- document.getElementById("social-notification-panel").hidePopup();
-
- if (!SocialUI.enabled)
- return;
- let panel = this.panel;
- let iframe = this.iframe;
-
- this.load(aURL, function() {
- sizeSocialPanelToContent(panel, iframe);
- let anchor = document.getElementById("social-sidebar-browser");
- if (panel.state == "open") {
- panel.moveToAnchor(anchor, "start_before", 0, yOffset, false);
- } else {
- panel.openPopup(anchor, "start_before", 0, yOffset, false, false);
- }
- if (aCallback) {
- try {
- aCallback(iframe.contentWindow);
- } catch(e) {
- Cu.reportError(e);
- }
- }
- });
- }
-}
-
-SocialShare = {
- // Called once, after window load, when the Social.provider object is initialized
- init: function() {},
-
- get panel() {
- return document.getElementById("social-share-panel");
- },
-
- get iframe() {
- // first element is our menu vbox.
- if (this.panel.childElementCount == 1)
- return null;
- else
- return this.panel.lastChild;
- },
-
- _createFrame: function() {
- let panel = this.panel;
- if (!SocialUI.enabled || this.iframe)
- return;
- this.panel.hidden = false;
- // create and initialize the panel for this window
- let iframe = document.createElement("iframe");
- iframe.setAttribute("type", "content");
- iframe.setAttribute("class", "social-share-frame");
- iframe.setAttribute("flex", "1");
- panel.appendChild(iframe);
- this.populateProviderMenu();
- },
-
- getSelectedProvider: function() {
- let provider;
- let lastProviderOrigin = this.iframe && this.iframe.getAttribute("origin");
- if (lastProviderOrigin) {
- provider = Social._getProviderFromOrigin(lastProviderOrigin);
- }
- if (!provider)
- provider = Social.provider || Social.defaultProvider;
- // if our provider has no shareURL, select the first one that does
- if (provider && !provider.shareURL) {
- let providers = [p for (p of Social.providers) if (p.shareURL)];
- provider = providers.length > 0 && providers[0];
- }
- return provider;
- },
-
- populateProviderMenu: function() {
- if (!this.iframe)
- return;
- let providers = [p for (p of Social.providers) if (p.shareURL)];
- let hbox = document.getElementById("social-share-provider-buttons");
- // selectable providers are inserted before the provider-menu seperator,
- // remove any menuitems in that area
- while (hbox.firstChild) {
- hbox.removeChild(hbox.firstChild);
- }
- // reset our share toolbar
- // only show a selection if there is more than one
- if (!SocialUI.enabled || providers.length < 2) {
- this.panel.firstChild.hidden = true;
- return;
- }
- let selectedProvider = this.getSelectedProvider();
- for (let provider of providers) {
- let button = document.createElement("toolbarbutton");
- button.setAttribute("class", "toolbarbutton share-provider-button");
- button.setAttribute("type", "radio");
- button.setAttribute("group", "share-providers");
- button.setAttribute("image", provider.iconURL);
- button.setAttribute("tooltiptext", provider.name);
- button.setAttribute("origin", provider.origin);
- button.setAttribute("oncommand", "SocialShare.sharePage(this.getAttribute('origin')); this.checked=true;");
- if (provider == selectedProvider) {
- this.defaultButton = button;
- }
- hbox.appendChild(button);
- }
- if (!this.defaultButton) {
- this.defaultButton = hbox.firstChild
- }
- this.defaultButton.setAttribute("checked", "true");
- this.panel.firstChild.hidden = false;
- },
-
- get shareButton() {
- return document.getElementById("social-share-button");
- },
-
- canSharePage: function(aURI) {
- // we do not enable sharing from private sessions
- if (PrivateBrowsingUtils.isWindowPrivate(window))
- return false;
-
- if (!aURI || !(aURI.schemeIs('http') || aURI.schemeIs('https')))
- return false;
- return true;
- },
-
- update: function() {
- let shareButton = this.shareButton;
- shareButton.hidden = !SocialUI.enabled ||
- [p for (p of Social.providers) if (p.shareURL)].length == 0;
- shareButton.disabled = shareButton.hidden || !this.canSharePage(gBrowser.currentURI);
-
- // also update the relevent command's disabled state so the keyboard
- // shortcut only works when available.
- let cmd = document.getElementById("Social:SharePage");
- cmd.setAttribute("disabled", shareButton.disabled ? "true" : "false");
- },
-
- onShowing: function() {
- this.shareButton.setAttribute("open", "true");
- },
-
- onHidden: function() {
- this.shareButton.removeAttribute("open");
- this.iframe.setAttribute("src", "data:text/plain;charset=utf8,");
- this.currentShare = null;
- },
-
- setErrorMessage: function() {
- let iframe = this.iframe;
- if (!iframe)
- return;
-
- iframe.removeAttribute("src");
- iframe.webNavigation.loadURI("about:socialerror?mode=compactInfo&origin=" +
- encodeURIComponent(iframe.getAttribute("origin")),
- null, null, null, null);
- sizeSocialPanelToContent(this.panel, iframe);
- },
-
- sharePage: function(providerOrigin, graphData) {
- // if providerOrigin is undefined, we use the last-used provider, or the
- // current/default provider. The provider selection in the share panel
- // will call sharePage with an origin for us to switch to.
- this._createFrame();
- let iframe = this.iframe;
- let provider;
- if (providerOrigin)
- provider = Social._getProviderFromOrigin(providerOrigin);
- else
- provider = this.getSelectedProvider();
- if (!provider || !provider.shareURL)
- return;
-
- // graphData is an optional param that either defines the full set of data
- // to be shared, or partial data about the current page. It is set by a call
- // in mozSocial API, or via nsContentMenu calls. If it is present, it MUST
- // define at least url. If it is undefined, we're sharing the current url in
- // the browser tab.
- let sharedURI = graphData ? Services.io.newURI(graphData.url, null, null) :
- gBrowser.currentURI;
- if (!this.canSharePage(sharedURI))
- return;
-
- // the point of this action type is that we can use existing share
- // endpoints (e.g. oexchange) that do not support additional
- // socialapi functionality. One tweak is that we shoot an event
- // containing the open graph data.
- let pageData = graphData ? graphData : this.currentShare;
- if (!pageData || sharedURI == gBrowser.currentURI) {
- pageData = OpenGraphBuilder.getData(gBrowser);
- if (graphData) {
- // overwrite data retreived from page with data given to us as a param
- for (let p in graphData) {
- pageData[p] = graphData[p];
- }
- }
- }
- this.currentShare = pageData;
-
- let shareEndpoint = this._generateShareEndpointURL(provider.shareURL, pageData);
-
- this._dynamicResizer = new DynamicResizeWatcher();
- // if we've already loaded this provider/page share endpoint, we don't want
- // to add another load event listener.
- let reload = true;
- let endpointMatch = shareEndpoint == iframe.getAttribute("src");
- let docLoaded = iframe.contentDocument && iframe.contentDocument.readyState == "complete";
- if (endpointMatch && docLoaded) {
- reload = shareEndpoint != iframe.contentDocument.location.spec;
- }
- if (!reload) {
- this._dynamicResizer.start(this.panel, iframe);
- iframe.docShell.isActive = true;
- iframe.docShell.isAppTab = true;
- let evt = iframe.contentDocument.createEvent("CustomEvent");
- evt.initCustomEvent("OpenGraphData", true, true, JSON.stringify(pageData));
- iframe.contentDocument.documentElement.dispatchEvent(evt);
- } else {
- // first time load, wait for load and dispatch after load
- iframe.addEventListener("load", function panelBrowserOnload(e) {
- iframe.removeEventListener("load", panelBrowserOnload, true);
- iframe.docShell.isActive = true;
- iframe.docShell.isAppTab = true;
- setTimeout(function() {
- if (SocialShare._dynamicResizer) { // may go null if hidden quickly
- SocialShare._dynamicResizer.start(iframe.parentNode, iframe);
- }
- }, 0);
- let evt = iframe.contentDocument.createEvent("CustomEvent");
- evt.initCustomEvent("OpenGraphData", true, true, JSON.stringify(pageData));
- iframe.contentDocument.documentElement.dispatchEvent(evt);
- }, true);
- }
- // always ensure that origin belongs to the endpoint
- let uri = Services.io.newURI(shareEndpoint, null, null);
- iframe.setAttribute("origin", provider.origin);
- iframe.setAttribute("src", shareEndpoint);
-
- let navBar = document.getElementById("nav-bar");
- let anchor = navBar.getAttribute("mode") == "text" ?
- document.getAnonymousElementByAttribute(this.shareButton, "class", "toolbarbutton-text") :
- document.getAnonymousElementByAttribute(this.shareButton, "class", "toolbarbutton-icon");
- this.panel.openPopup(anchor, "bottomcenter topright", 0, 0, false, false);
- Social.setErrorListener(iframe, this.setErrorMessage.bind(this));
- },
-
- _generateShareEndpointURL: function(shareURL, pageData) {
- // support for existing share endpoints by supporting their querystring
- // arguments. parse the query string template and do replacements where
- // necessary the query names may be different than ours, so we could see
- // u=%{url} or url=%{url}
- let [shareEndpoint, queryString] = shareURL.split("?");
- let query = {};
- if (queryString) {
- queryString.split('&').forEach(function (val) {
- let [name, value] = val.split('=');
- let p = /%\{(.+)\}/.exec(value);
- if (!p) {
- // preserve non-template query vars
- query[name] = value;
- } else if (pageData[p[1]]) {
- query[name] = pageData[p[1]];
- } else if (p[1] == "body") {
- // build a body for emailers
- let body = "";
- if (pageData.title)
- body += pageData.title + "\n\n";
- if (pageData.description)
- body += pageData.description + "\n\n";
- if (pageData.text)
- body += pageData.text + "\n\n";
- body += pageData.url;
- query["body"] = body;
- }
- });
- }
- var str = [];
- for (let p in query)
- str.push(p + "=" + encodeURIComponent(query[p]));
- if (str.length)
- shareEndpoint = shareEndpoint + "?" + str.join("&");
- return shareEndpoint;
- }
-};
-
-SocialMark = {
- // Called once, after window load, when the Social.provider object is initialized
- init: function SSB_init() {
- },
-
- get button() {
- return document.getElementById("social-mark-button");
- },
-
- canMarkPage: function SSB_canMarkPage(aURI) {
- // We only allow sharing of http or https
- return aURI && (aURI.schemeIs('http') || aURI.schemeIs('https'));
- },
-
- // Called when the Social.provider changes
- update: function SSB_updateButtonState() {
- let markButton = this.button;
- // always show button if provider supports marks
- markButton.hidden = !SocialUI.enabled || Social.provider.pageMarkInfo == null;
- markButton.disabled = markButton.hidden || !this.canMarkPage(gBrowser.currentURI);
-
- // also update the relevent command's disabled state so the keyboard
- // shortcut only works when available.
- let cmd = document.getElementById("Social:TogglePageMark");
- cmd.setAttribute("disabled", markButton.disabled ? "true" : "false");
- },
-
- togglePageMark: function(aCallback) {
- if (this.button.disabled)
- return;
- this.toggleURIMark(gBrowser.currentURI, aCallback)
- },
-
- toggleURIMark: function(aURI, aCallback) {
- let update = function(marked) {
- this._updateMarkState(marked);
- if (aCallback)
- aCallback(marked);
- }.bind(this);
- Social.isURIMarked(aURI, function(marked) {
- if (marked) {
- Social.unmarkURI(aURI, update);
- } else {
- Social.markURI(aURI, update);
- }
- });
- },
-
- updateMarkState: function SSB_updateMarkState() {
- this.update();
- if (!this.button.hidden)
- Social.isURIMarked(gBrowser.currentURI, this._updateMarkState.bind(this));
- },
-
- _updateMarkState: function(currentPageMarked) {
- // callback for isURIMarked
- let markButton = this.button;
- let pageMarkInfo = SocialUI.enabled ? Social.provider.pageMarkInfo : null;
-
- // Update the mark button, if present
- if (!markButton || markButton.hidden || !pageMarkInfo)
- return;
-
- let imageURL;
- if (!markButton.disabled && currentPageMarked) {
- markButton.setAttribute("marked", "true");
- markButton.setAttribute("label", pageMarkInfo.messages.markedLabel);
- markButton.setAttribute("tooltiptext", pageMarkInfo.messages.markedTooltip);
- imageURL = pageMarkInfo.images.marked;
- } else {
- markButton.removeAttribute("marked");
- markButton.setAttribute("label", pageMarkInfo.messages.unmarkedLabel);
- markButton.setAttribute("tooltiptext", pageMarkInfo.messages.unmarkedTooltip);
- imageURL = pageMarkInfo.images.unmarked;
- }
- markButton.style.listStyleImage = "url(" + imageURL + ")";
- }
-};
-
-SocialMenu = {
- init: function SocialMenu_init() {
- },
-
- populate: function SocialMenu_populate() {
- let submenu = document.getElementById("menu_social-statusarea-popup");
- let ambientMenuItems = submenu.getElementsByClassName("ambient-menuitem");
- while (ambientMenuItems.length)
- submenu.removeChild(ambientMenuItems.item(0));
-
- let separator = document.getElementById("socialAmbientMenuSeparator");
- separator.hidden = true;
- let provider = SocialUI.enabled ? Social.provider : null;
- if (!provider)
- return;
-
- let iconNames = Object.keys(provider.ambientNotificationIcons);
- for (let name of iconNames) {
- let icon = provider.ambientNotificationIcons[name];
- if (!icon.label || !icon.menuURL)
- continue;
- separator.hidden = false;
- let menuitem = document.createElement("menuitem");
- menuitem.setAttribute("label", icon.label);
- menuitem.classList.add("ambient-menuitem");
- menuitem.addEventListener("command", function() {
- openUILinkIn(icon.menuURL, "tab");
- }, false);
- submenu.insertBefore(menuitem, separator);
- }
- }
-};
-
-// XXX Need to audit that this is being initialized correctly
-SocialToolbar = {
- // Called once, after window load, when the Social.provider object is
- // initialized.
- init: function SocialToolbar_init() {
- this._dynamicResizer = new DynamicResizeWatcher();
- },
-
- update: function() {
- this._updateButtonHiddenState();
- this.updateProvider();
- this.populateProviderMenus();
- },
-
- // Called when the Social.provider changes
- updateProvider: function () {
- let provider = Social.provider;
- if (provider) {
- this.button.setAttribute("label", provider.name);
- this.button.setAttribute("tooltiptext", provider.name);
- this.button.style.listStyleImage = "url(" + provider.iconURL + ")";
-
- this.updateProfile();
- } else {
- this.button.setAttribute("label", gNavigatorBundle.getString("service.toolbarbutton.label"));
- this.button.setAttribute("tooltiptext", gNavigatorBundle.getString("service.toolbarbutton.tooltiptext"));
- this.button.style.removeProperty("list-style-image");
- }
- this.updateButton();
- },
-
- get button() {
- return document.getElementById("social-provider-button");
- },
-
- // Note: this doesn't actually handle hiding the toolbar button,
- // socialActiveBroadcaster is responsible for that.
- _updateButtonHiddenState: function SocialToolbar_updateButtonHiddenState() {
- let socialEnabled = SocialUI.enabled;
- for (let className of ["social-statusarea-separator", "social-statusarea-user"]) {
- for (let element of document.getElementsByClassName(className))
- element.hidden = !socialEnabled;
- }
- let toggleNotificationsCommand = document.getElementById("Social:ToggleNotifications");
- toggleNotificationsCommand.setAttribute("hidden", !socialEnabled);
-
- if (!Social.haveLoggedInUser() || !socialEnabled) {
- let parent = document.getElementById("social-notification-panel");
- while (parent.hasChildNodes()) {
- let frame = parent.firstChild;
- SharedFrame.forgetGroup(frame.id);
- parent.removeChild(frame);
- }
-
- let tbi = document.getElementById("social-toolbar-item");
- if (tbi) {
- // SocialMark is the last button allways
- let next = SocialMark.button.previousSibling;
- while (next != this.button) {
- tbi.removeChild(next);
- next = SocialMark.button.previousSibling;
- }
- }
- }
- },
-
- updateProfile: function SocialToolbar_updateProfile() {
- // Profile may not have been initialized yet, since it depends on a worker
- // response. In that case we'll be called again when it's available, via
- // social:profile-changed
- if (!Social.provider)
- return;
- let profile = Social.provider.profile || {};
- let userPortrait = profile.portrait;
-
- let userDetailsBroadcaster = document.getElementById("socialBroadcaster_userDetails");
- let loggedInStatusValue = profile.userName ||
- userDetailsBroadcaster.getAttribute("notLoggedInLabel");
-
- // "image" and "label" are used by Mac's native menus that do not render the menuitem's children
- // elements. "src" and "value" are used by the image/label children on the other platforms.
- if (userPortrait) {
- userDetailsBroadcaster.setAttribute("src", userPortrait);
- userDetailsBroadcaster.setAttribute("image", userPortrait);
- } else {
- userDetailsBroadcaster.removeAttribute("src");
- userDetailsBroadcaster.removeAttribute("image");
- }
-
- userDetailsBroadcaster.setAttribute("value", loggedInStatusValue);
- userDetailsBroadcaster.setAttribute("label", loggedInStatusValue);
- },
-
- updateButton: function SocialToolbar_updateButton() {
- this._updateButtonHiddenState();
- let panel = document.getElementById("social-notification-panel");
- panel.hidden = !SocialUI.enabled;
-
- let command = document.getElementById("Social:ToggleNotifications");
- command.setAttribute("checked", Services.prefs.getBoolPref("social.toast-notifications.enabled"));
-
- const CACHE_PREF_NAME = "social.cached.ambientNotificationIcons";
- // provider.profile == undefined means no response yet from the provider
- // to tell us whether the user is logged in or not.
- if (!SocialUI.enabled ||
- (!Social.haveLoggedInUser() && Social.provider.profile !== undefined)) {
- // Either no enabled provider, or there is a provider and it has
- // responded with a profile and the user isn't loggedin. The icons
- // etc have already been removed by updateButtonHiddenState, so we want
- // to nuke any cached icons we have and get out of here!
- Services.prefs.clearUserPref(CACHE_PREF_NAME);
- return;
- }
- let icons = Social.provider.ambientNotificationIcons;
- let iconNames = Object.keys(icons);
-
- if (Social.provider.profile === undefined) {
- // provider has not told us about the login state yet - see if we have
- // a cached version for this provider.
- let cached;
- try {
- cached = JSON.parse(Services.prefs.getComplexValue(CACHE_PREF_NAME,
- Ci.nsISupportsString).data);
- } catch (ex) {}
- if (cached && cached.provider == Social.provider.origin && cached.data) {
- icons = cached.data;
- iconNames = Object.keys(icons);
- // delete the counter data as it is almost certainly stale.
- for each(let name in iconNames) {
- icons[name].counter = '';
- }
- }
- } else {
- // We have a logged in user - save the current set of icons back to the
- // "cache" so we can use them next startup.
- let str = Cc["@mozilla.org/supports-string;1"].createInstance(Ci.nsISupportsString);
- str.data = JSON.stringify({provider: Social.provider.origin, data: icons});
- Services.prefs.setComplexValue(CACHE_PREF_NAME,
- Ci.nsISupportsString,
- str);
- }
-
- let toolbarButtons = document.createDocumentFragment();
-
- let createdFrames = [];
-
- for each(let name in iconNames) {
- let icon = icons[name];
-
- let notificationFrameId = "social-status-" + icon.name;
- let notificationFrame = document.getElementById(notificationFrameId);
-
- if (!notificationFrame) {
- notificationFrame = SharedFrame.createFrame(
- notificationFrameId, /* frame name */
- panel, /* parent */
- {
- "type": "content",
- "mozbrowser": "true",
- "class": "social-panel-frame",
- "id": notificationFrameId,
- "tooltip": "aHTMLTooltip",
-
- // work around bug 793057 - by making the panel roughly the final size
- // we are more likely to have the anchor in the correct position.
- "style": "width: " + PANEL_MIN_WIDTH + "px;",
-
- "origin": Social.provider.origin,
- "src": icon.contentPanel
- }
- );
-
- createdFrames.push(notificationFrame);
- } else {
- notificationFrame.setAttribute("origin", Social.provider.origin);
- SharedFrame.updateURL(notificationFrameId, icon.contentPanel);
- }
-
- let toolbarButtonId = "social-notification-icon-" + icon.name;
- let toolbarButton = document.getElementById(toolbarButtonId);
- if (!toolbarButton) {
- toolbarButton = document.createElement("toolbarbutton");
- toolbarButton.setAttribute("type", "badged");
- toolbarButton.classList.add("toolbarbutton-1");
- toolbarButton.setAttribute("id", toolbarButtonId);
- toolbarButton.setAttribute("notificationFrameId", notificationFrameId);
- toolbarButton.addEventListener("mousedown", function (event) {
- if (event.button == 0 && panel.state == "closed")
- SocialToolbar.showAmbientPopup(toolbarButton);
- });
-
- toolbarButtons.appendChild(toolbarButton);
- }
-
- toolbarButton.style.listStyleImage = "url(" + icon.iconURL + ")";
- toolbarButton.setAttribute("label", icon.label);
- toolbarButton.setAttribute("tooltiptext", icon.label);
-
- let badge = icon.counter || "";
- toolbarButton.setAttribute("badge", badge);
- let ariaLabel = icon.label;
- // if there is a badge value, we must use a localizable string to insert it.
- if (badge)
- ariaLabel = gNavigatorBundle.getFormattedString("social.aria.toolbarButtonBadgeText",
- [ariaLabel, badge]);
- toolbarButton.setAttribute("aria-label", ariaLabel);
- }
- let socialToolbarItem = document.getElementById("social-toolbar-item");
- socialToolbarItem.insertBefore(toolbarButtons, SocialMark.button);
-
- for (let frame of createdFrames) {
- if (frame.socialErrorListener) {
- frame.socialErrorListener.remove();
- }
- if (frame.docShell) {
- frame.docShell.isActive = false;
- Social.setErrorListener(frame, this.setPanelErrorMessage.bind(this));
- }
- }
- },
-
- showAmbientPopup: function SocialToolbar_showAmbientPopup(aToolbarButton) {
- // Hide any other social panels that may be open.
- SocialFlyout.panel.hidePopup();
-
- let panel = document.getElementById("social-notification-panel");
- let notificationFrameId = aToolbarButton.getAttribute("notificationFrameId");
- let notificationFrame = document.getElementById(notificationFrameId);
-
- let wasAlive = SharedFrame.isGroupAlive(notificationFrameId);
- SharedFrame.setOwner(notificationFrameId, notificationFrame);
-
- // Clear dimensions on all browsers so the panel size will
- // only use the selected browser.
- let frameIter = panel.firstElementChild;
- while (frameIter) {
- frameIter.collapsed = (frameIter != notificationFrame);
- frameIter = frameIter.nextElementSibling;
- }
-
- function dispatchPanelEvent(name) {
- let evt = notificationFrame.contentDocument.createEvent("CustomEvent");
- evt.initCustomEvent(name, true, true, {});
- notificationFrame.contentDocument.documentElement.dispatchEvent(evt);
- }
-
- let dynamicResizer = this._dynamicResizer;
- panel.addEventListener("popuphidden", function onpopuphiding() {
- panel.removeEventListener("popuphidden", onpopuphiding);
- aToolbarButton.removeAttribute("open");
- aToolbarButton.parentNode.removeAttribute("open");
- dynamicResizer.stop();
- notificationFrame.docShell.isActive = false;
- dispatchPanelEvent("socialFrameHide");
- });
-
- panel.addEventListener("popupshown", function onpopupshown() {
- panel.removeEventListener("popupshown", onpopupshown);
- // This attribute is needed on both the button and the
- // containing toolbaritem since the buttons on OS X have
- // moz-appearance:none, while their container gets
- // moz-appearance:toolbarbutton due to the way that toolbar buttons
- // get combined on OS X.
- aToolbarButton.setAttribute("open", "true");
- aToolbarButton.parentNode.setAttribute("open", "true");
- notificationFrame.docShell.isActive = true;
- notificationFrame.docShell.isAppTab = true;
- if (notificationFrame.contentDocument.readyState == "complete" && wasAlive) {
- dynamicResizer.start(panel, notificationFrame);
- dispatchPanelEvent("socialFrameShow");
- } else {
- // first time load, wait for load and dispatch after load
- notificationFrame.addEventListener("load", function panelBrowserOnload(e) {
- notificationFrame.removeEventListener("load", panelBrowserOnload, true);
- dynamicResizer.start(panel, notificationFrame);
- setTimeout(function() {
- dispatchPanelEvent("socialFrameShow");
- }, 0);
- }, true);
- }
- });
-
- let navBar = document.getElementById("nav-bar");
- let anchor = navBar.getAttribute("mode") == "text" ?
- document.getAnonymousElementByAttribute(aToolbarButton, "class", "toolbarbutton-text") :
- document.getAnonymousElementByAttribute(aToolbarButton, "class", "toolbarbutton-badge-container");
- // Bug 849216 - open the popup in a setTimeout so we avoid the auto-rollup
- // handling from preventing it being opened in some cases.
- setTimeout(function() {
- panel.openPopup(anchor, "bottomcenter topright", 0, 0, false, false);
- }, 0);
- },
-
- setPanelErrorMessage: function SocialToolbar_setPanelErrorMessage(aNotificationFrame) {
- if (!aNotificationFrame)
- return;
-
- let src = aNotificationFrame.getAttribute("src");
- aNotificationFrame.removeAttribute("src");
- aNotificationFrame.webNavigation.loadURI("about:socialerror?mode=tryAgainOnly&url=" +
- encodeURIComponent(src), null, null, null, null);
- let panel = aNotificationFrame.parentNode;
- sizeSocialPanelToContent(panel, aNotificationFrame);
- },
-
- populateProviderMenus: function SocialToolbar_renderProviderMenus() {
- let providerMenuSeps = document.getElementsByClassName("social-provider-menu");
- for (let providerMenuSep of providerMenuSeps)
- this._populateProviderMenu(providerMenuSep);
- },
-
- _populateProviderMenu: function SocialToolbar_renderProviderMenu(providerMenuSep) {
- let menu = providerMenuSep.parentNode;
- // selectable providers are inserted before the provider-menu seperator,
- // remove any menuitems in that area
- while (providerMenuSep.previousSibling.nodeName == "menuitem") {
- menu.removeChild(providerMenuSep.previousSibling);
- }
- // only show a selection if enabled and there is more than one
- let providers = [p for (p of Social.providers) if (p.workerURL || p.sidebarURL)];
- if (providers.length < 2) {
- providerMenuSep.hidden = true;
- return;
- }
- for (let provider of providers) {
- let menuitem = document.createElement("menuitem");
- menuitem.className = "menuitem-iconic social-provider-menuitem";
- menuitem.setAttribute("image", provider.iconURL);
- menuitem.setAttribute("label", provider.name);
- menuitem.setAttribute("origin", provider.origin);
- if (provider == Social.provider) {
- menuitem.setAttribute("checked", "true");
- } else {
- menuitem.setAttribute("oncommand", "Social.setProviderByOrigin(this.getAttribute('origin'));");
- }
- menu.insertBefore(menuitem, providerMenuSep);
- }
- providerMenuSep.hidden = false;
- }
-}
-
-SocialSidebar = {
- // Called once, after window load, when the Social.provider object is initialized
- init: function SocialSidebar_init() {
- let sbrowser = document.getElementById("social-sidebar-browser");
- Social.setErrorListener(sbrowser, this.setSidebarErrorMessage.bind(this));
- // setting isAppTab causes clicks on untargeted links to open new tabs
- sbrowser.docShell.isAppTab = true;
- },
-
- // Whether the sidebar can be shown for this window.
- get canShow() {
- return SocialUI.enabled && Social.provider.sidebarURL;
- },
-
- // Whether the user has toggled the sidebar on (for windows where it can appear)
- get opened() {
- return Services.prefs.getBoolPref("social.sidebar.open") && !document.mozFullScreen;
- },
-
- setSidebarVisibilityState: function(aEnabled) {
- let sbrowser = document.getElementById("social-sidebar-browser");
- // it's possible we'll be called twice with aEnabled=false so let's
- // just assume we may often be called with the same state.
- if (aEnabled == sbrowser.docShellIsActive)
- return;
- sbrowser.docShellIsActive = aEnabled;
- let evt = sbrowser.contentDocument.createEvent("CustomEvent");
- evt.initCustomEvent(aEnabled ? "socialFrameShow" : "socialFrameHide", true, true, {});
- sbrowser.contentDocument.documentElement.dispatchEvent(evt);
- },
-
- update: function SocialSidebar_update() {
- clearTimeout(this._unloadTimeoutId);
- // Hide the toggle menu item if the sidebar cannot appear
- let command = document.getElementById("Social:ToggleSidebar");
- command.setAttribute("hidden", this.canShow ? "false" : "true");
-
- // Hide the sidebar if it cannot appear, or has been toggled off.
- // Also set the command "checked" state accordingly.
- let hideSidebar = !this.canShow || !this.opened;
- let broadcaster = document.getElementById("socialSidebarBroadcaster");
- broadcaster.hidden = hideSidebar;
- command.setAttribute("checked", !hideSidebar);
-
- let sbrowser = document.getElementById("social-sidebar-browser");
-
- if (hideSidebar) {
- sbrowser.removeEventListener("load", SocialSidebar._loadListener, true);
- this.setSidebarVisibilityState(false);
- // If we've been disabled, unload the sidebar content immediately;
- // if the sidebar was just toggled to invisible, wait a timeout
- // before unloading.
- if (!this.canShow) {
- this.unloadSidebar();
- } else {
- this._unloadTimeoutId = setTimeout(
- this.unloadSidebar,
- Services.prefs.getIntPref("social.sidebar.unload_timeout_ms")
- );
- }
- } else {
- sbrowser.setAttribute("origin", Social.provider.origin);
- if (Social.provider.errorState == "frameworker-error") {
- SocialSidebar.setSidebarErrorMessage();
- return;
- }
-
- // Make sure the right sidebar URL is loaded
- if (sbrowser.getAttribute("src") != Social.provider.sidebarURL) {
- sbrowser.setAttribute("src", Social.provider.sidebarURL);
- PopupNotifications.locationChange(sbrowser);
- }
-
- // if the document has not loaded, delay until it is
- if (sbrowser.contentDocument.readyState != "complete") {
- sbrowser.addEventListener("load", SocialSidebar._loadListener, true);
- } else {
- this.setSidebarVisibilityState(true);
- }
- }
- },
-
- _loadListener: function SocialSidebar_loadListener() {
- let sbrowser = document.getElementById("social-sidebar-browser");
- sbrowser.removeEventListener("load", SocialSidebar._loadListener, true);
- SocialSidebar.setSidebarVisibilityState(true);
- },
-
- unloadSidebar: function SocialSidebar_unloadSidebar() {
- let sbrowser = document.getElementById("social-sidebar-browser");
- if (!sbrowser.hasAttribute("origin"))
- return;
-
- sbrowser.stop();
- sbrowser.removeAttribute("origin");
- sbrowser.setAttribute("src", "about:blank");
- SocialFlyout.unload();
- },
-
- _unloadTimeoutId: 0,
-
- setSidebarErrorMessage: function() {
- let sbrowser = document.getElementById("social-sidebar-browser");
- // a frameworker error "trumps" a sidebar error.
- if (Social.provider.errorState == "frameworker-error") {
- sbrowser.setAttribute("src", "about:socialerror?mode=workerFailure");
- } else {
- let url = encodeURIComponent(Social.provider.sidebarURL);
- sbrowser.loadURI("about:socialerror?mode=tryAgain&url=" + url, null, null);
- }
- }
-}
-
-})();
diff --git a/browser/base/content/browser.css b/browser/base/content/browser.css
index d7a1c3591..a44b46195 100644
--- a/browser/base/content/browser.css
+++ b/browser/base/content/browser.css
@@ -668,56 +668,3 @@ html|*#gcli-output-frame,
toolbarbutton[type="badged"] {
-moz-binding: url("chrome://browser/content/urlbarBindings.xml#toolbarbutton-badged");
}
-
-/* Note the chatbox 'width' values are duplicated in socialchat.xml */
-chatbox {
- -moz-binding: url("chrome://browser/content/socialchat.xml#chatbox");
- transition: height 150ms ease-out, width 150ms ease-out;
- height: 285px;
- width: 260px; /* CHAT_WIDTH_OPEN in socialchat.xml */
-}
-
-chatbox[minimized="true"] {
- width: 160px;
- height: 20px; /* CHAT_WIDTH_MINIMIZED in socialchat.xml */
-}
-
-chatbar {
- -moz-binding: url("chrome://browser/content/socialchat.xml#chatbar");
- height: 0;
- max-height: 0;
-}
-
-/* full screen chat window support */
-chatbar:-moz-full-screen-ancestor,
-chatbox:-moz-full-screen-ancestor {
- border: none;
- position: fixed !important;
- top: 0 !important;
- left: 0 !important;
- right: 0 !important;
- bottom: 0 !important;
- width: 100% !important;
- height: 100% !important;
- margin: 0 !important;
- min-width: 0 !important;
- max-width: none !important;
- min-height: 0 !important;
- max-height: none !important;
- box-sizing: border-box !important;
-}
-
-/* hide chat chrome when chat is fullscreen */
-chatbox:-moz-full-screen-ancestor > .chat-titlebar {
- display: none;
-}
-
-/* hide chatbar if browser tab is fullscreen */
-*:-moz-full-screen-ancestor chatbar:not(:-moz-full-screen-ancestor) {
- display: none;
-}
-
-/* hide sidebar when fullscreen */
-*:-moz-full-screen-ancestor #social-sidebar-box:not(:-moz-full-screen-ancestor) {
- display: none;
-}
diff --git a/browser/base/content/browser.js b/browser/base/content/browser.js
index a832b7841..2c5dbc9d9 100644
--- a/browser/base/content/browser.js
+++ b/browser/base/content/browser.js
@@ -123,9 +123,6 @@ XPCOMUtils.defineLazyGetter(this, "BrowserDebuggerProcess", function() {
});
#endif
-XPCOMUtils.defineLazyModuleGetter(this, "Social",
- "resource:///modules/Social.jsm");
-
XPCOMUtils.defineLazyModuleGetter(this, "PageThumbs",
"resource://gre/modules/PageThumbs.jsm");
@@ -158,7 +155,6 @@ let gInitialPages = [
#ifdef MOZ_SAFE_BROWSING
#include browser-safebrowsing.js
#endif
-#include browser-social.js
#include browser-tabPreviews.js
#include browser-thumbnails.js
#include browser-webrtcUI.js
@@ -805,10 +801,6 @@ var gBrowserInit = {
// setup our MozApplicationManifest listener
gBrowser.addEventListener("MozApplicationManifest",
OfflineApps, false);
- // listen for offline apps on social
- let socialBrowser = document.getElementById("social-sidebar-browser");
- socialBrowser.addEventListener("MozApplicationManifest",
- OfflineApps, false);
// setup simple gestures support
gGestureSupport.init(true);
@@ -1025,7 +1017,6 @@ var gBrowserInit = {
OfflineApps.init();
IndexedDBPromptHelper.init();
gFormSubmitObserver.init();
- SocialUI.init();
AddonManager.addAddonListener(AddonsMgrListener);
WebrtcIndicator.init();
@@ -1396,7 +1387,6 @@ var gBrowserInit = {
OfflineApps.uninit();
IndexedDBPromptHelper.uninit();
AddonManager.removeAddonListener(AddonsMgrListener);
- SocialUI.uninit();
}
// Final window teardown, do this last.
@@ -1463,8 +1453,6 @@ var gBrowserInit = {
}
}
- SocialUI.nonBrowserWindowInit();
-
if (PrivateBrowsingUtils.permanentPrivateBrowsing) {
document.getElementById("macDockMenuNewWindow").hidden = true;
}
@@ -3474,8 +3462,6 @@ function BrowserToolboxCustomizeDone(aToolboxChanged) {
URLBarSetURI();
XULBrowserWindow.asyncUpdateUI();
BookmarkingUI.updateStarState();
- SocialMark.updateMarkState();
- SocialShare.update();
}
TabsInTitlebar.allowedBy("customizing-toolbars", true);
@@ -3767,7 +3753,6 @@ var XULBrowserWindow = {
// Called before links are navigated to to allow us to retarget them if needed.
onBeforeLinkTraversal: function(originalTarget, linkURI, linkNode, isAppTab) {
let target = this._onBeforeLinkTraversal(originalTarget, linkURI, linkNode, isAppTab);
- SocialUI.closeSocialPanelForLinkTraversal(target, linkNode);
return target;
},
@@ -3959,8 +3944,6 @@ var XULBrowserWindow = {
// Update starring UI
BookmarkingUI.updateStarState();
- SocialMark.updateMarkState();
- SocialShare.update();
}
// Show or hide browser chrome based on the whitelist
diff --git a/browser/base/content/browser.xul b/browser/base/content/browser.xul
index 8cdbf2fe7..2fde1c9cb 100644
--- a/browser/base/content/browser.xul
+++ b/browser/base/content/browser.xul
@@ -181,65 +181,6 @@
</hbox>
</panel>
- <panel id="socialActivatedNotification"
- type="arrow"
- hidden="true"
- consumeoutsideclicks="true"
- align="start"
- orient="horizontal"
- role="alert">
- <image id="social-activation-icon" class="popup-notification-icon"/>
- <vbox flex="1">
- <description id="social-activation-message" class="popup-notification-description">&social.activated.description;</description>
- <spacer flex="1"/>
- <hbox pack="start" align="center" class="popup-notification-button-container">
- <label id="social-undoactivation-button"
- class="text-link"
- value="&social.activated.undo.label;"
- accesskey="&social.activated.undo.accesskey;"
- onclick="SocialUI.undoActivation(this);"/>
- <spacer flex="1"/>
- <button id="social-activation-button"
- default="true"
- autofocus="autofocus"
- label="&social.ok.label;"
- accesskey="&social.ok.accesskey;"
- oncommand="SocialUI.activationPanel.hidePopup();"/>
- </hbox>
- </vbox>
- </panel>
-
- <panel id="social-share-panel"
- class="social-panel"
- type="arrow"
- orient="horizontal"
- onpopupshowing="SocialShare.onShowing()"
- onpopuphidden="SocialShare.onHidden()"
- consumeoutsideclicks="true"
- hidden="true">
- <vbox class="social-share-toolbar">
- <vbox id="social-share-provider-buttons" flex="1"/>
- </vbox>
- </panel>
-
- <panel id="social-notification-panel"
- class="social-panel"
- type="arrow"
- hidden="true"
- noautofocus="true"/>
- <panel id="social-flyout-panel"
- class="social-panel"
- onpopupshown="SocialFlyout.onShown()"
- onpopuphidden="SocialFlyout.onHidden()"
- side="right"
- type="arrow"
- hidden="true"
- flip="slide"
- rolluponmousewheel="true"
- consumeoutsideclicks="false"
- noautofocus="true"
- position="topcenter topright"/>
-
<menupopup id="toolbar-context-menu"
onpopupshowing="onViewToolbarsPopupShowing(event);">
<menuseparator/>
@@ -664,69 +605,6 @@
</menupopup>
</toolbarbutton>
- <toolbarbutton id="social-share-button"
- class="toolbarbutton-1 chromeclass-toolbar-additional"
- hidden="true"
- label="&sharePageCmd.label;"
- tooltiptext="&sharePageCmd.label;"
- command="Social:SharePage"/>
-
- <toolbaritem id="social-toolbar-item"
- class="chromeclass-toolbar-additional"
- removable="false"
- title="&socialToolbar.title;"
- hidden="true"
- skipintoolbarset="true"
- observes="socialActiveBroadcaster">
- <toolbarbutton id="social-notification-icon" class="default-notification-icon toolbarbutton-1 notification-anchor-icon"
- oncommand="PopupNotifications._reshowNotifications(this,
- document.getElementById('social-sidebar-browser'));"/>
- <toolbarbutton id="social-provider-button"
- class="toolbarbutton-1"
- type="menu">
- <menupopup id="social-statusarea-popup">
- <menuitem class="social-statusarea-user menuitem-iconic" pack="start" align="center"
- observes="socialBroadcaster_userDetails"
- oncommand="SocialUI.showProfile(); document.getElementById('social-statusarea-popup').hidePopup();">
- <image class="social-statusarea-user-portrait"
- observes="socialBroadcaster_userDetails"/>
- <vbox>
- <label class="social-statusarea-loggedInStatus"
- observes="socialBroadcaster_userDetails"/>
- </vbox>
- </menuitem>
-#ifndef XP_WIN
- <menuseparator class="social-statusarea-separator"/>
-#endif
- <menuitem class="social-toggle-sidebar-menuitem"
- type="checkbox"
- autocheck="false"
- command="Social:ToggleSidebar"
- label="&social.toggleSidebar.label;"
- accesskey="&social.toggleSidebar.accesskey;"/>
- <menuitem class="social-toggle-notifications-menuitem"
- type="checkbox"
- autocheck="false"
- command="Social:ToggleNotifications"
- label="&social.toggleNotifications.label;"
- accesskey="&social.toggleNotifications.accesskey;"/>
- <menuitem class="social-toggle-menuitem" command="Social:Toggle"/>
- <menuseparator/>
- <menuseparator class="social-provider-menu" hidden="true"/>
- <menuitem class="social-addons-menuitem" command="Social:Addons"
- label="&social.addons.label;"/>
- <menuitem label="&social.learnMore.label;"
- accesskey="&social.learnMore.accesskey;"
- oncommand="SocialUI.showLearnMore();"/>
- </menupopup>
- </toolbarbutton>
- <toolbarbutton id="social-mark-button"
- class="toolbarbutton-1"
- hidden="true"
- disabled="true"
- command="Social:TogglePageMark"/>
- </toolbaritem>
-
<hbox id="window-controls" hidden="true" pack="end">
<toolbarbutton id="minimize-button"
tooltiptext="&fullScreenMinimize.tooltip;"
@@ -993,22 +871,6 @@
<chatbar id="pinnedchats" layer="true" mousethrough="always" hidden="true"/>
<statuspanel id="statusbar-display" inactive="true"/>
</vbox>
- <splitter id="social-sidebar-splitter"
- class="chromeclass-extrachrome sidebar-splitter"
- observes="socialSidebarBroadcaster"/>
- <vbox id="social-sidebar-box"
- class="chromeclass-extrachrome"
- observes="socialSidebarBroadcaster"
- persist="width">
- <browser id="social-sidebar-browser"
- type="content"
- context="contentAreaContextMenu"
- disableglobalhistory="true"
- tooltip="aHTMLTooltip"
- popupnotificationanchor="social-notification-icon"
- flex="1"
- style="min-width: 14em; width: 18em; max-width: 36em;"/>
- </vbox>
<vbox id="browser-border-end" hidden="true" layer="true"/>
</hbox>
diff --git a/browser/base/content/chatWindow.xul b/browser/base/content/chatWindow.xul
deleted file mode 100644
index 4b240acf6..000000000
--- a/browser/base/content/chatWindow.xul
+++ /dev/null
@@ -1,109 +0,0 @@
-#filter substitution
-<?xml version="1.0"?>
-
-# -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
-# This Source Code Form is subject to the terms of the Mozilla Public
-# License, v. 2.0. If a copy of the MPL was not distributed with this
-# file, You can obtain one at http://mozilla.org/MPL/2.0/.
-
-<?xml-stylesheet href="chrome://browser/content/browser.css" type="text/css"?>
-<?xml-stylesheet href="chrome://browser/skin/" type="text/css"?>
-<?xul-overlay href="chrome://browser/content/baseMenuOverlay.xul"?>
-<?xul-overlay href="chrome://global/content/editMenuOverlay.xul"?>
-<?xul-overlay href="chrome://browser/content/places/placesOverlay.xul"?>
-
-#include browser-doctype.inc
-
-<window id="chat-window"
- windowtype="Social:Chat"
- xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
- xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
- title="&mainWindow.title;@PRE_RELEASE_SUFFIX@"
- onload="gChatWindow.onLoad();"
- onunload="gChatWindow.onUnload();"
- macanimationtype="document"
- fullscreenbutton="true"
-# width and height are also used in socialchat.xml: chatbar dragend handler
- width="400px"
- height="420px"
- persist="screenX screenY width height sizemode">
-
- <script type="application/javascript" src="chrome://global/content/globalOverlay.js"/>
- <script type="application/javascript" src="chrome://global/content/contentAreaUtils.js"/>
- <script type="application/javascript" src="chrome://browser/content/nsContextMenu.js"/>
-
-#include global-scripts.inc
-
-<script type="application/javascript">
-
-var gChatWindow = {
- // cargo-culted from browser.js for nonBrowserStartup, but we're slightly
- // different what what we need to leave enabled
- onLoad: function() {
- // Disable inappropriate commands / submenus
- var disabledItems = ['Browser:SavePage',
- 'Browser:SendLink', 'cmd_pageSetup', 'cmd_print', 'cmd_find', 'cmd_findAgain',
- 'viewToolbarsMenu', 'viewSidebarMenuMenu',
- 'viewFullZoomMenu', 'pageStyleMenu', 'charsetMenu',
- 'viewHistorySidebar', 'Browser:AddBookmarkAs', 'Browser:BookmarkAllTabs',
- 'Browser:ToggleTabView', 'Browser:ToggleAddonBar'];
-
- for (let disabledItem of disabledItems) {
- document.getElementById(disabledItem).setAttribute("disabled", "true");
- }
-
- // initialise the offline listener
- BrowserOffline.init();
- },
-
- onUnload: function() {
- BrowserOffline.uninit();
- }
-}
-
-// define a popupnotifications handler for this window. we don't use
-// an iconbox here, and only support the browser frame for chat.
-XPCOMUtils.defineLazyGetter(this, "PopupNotifications", function () {
- let tmp = {};
- Cu.import("resource://gre/modules/PopupNotifications.jsm", tmp);
- try {
- return new tmp.PopupNotifications(document.getElementById("chatter").content,
- document.getElementById("notification-popup"),
- null);
- } catch (ex) {
- console.error(ex);
- return null;
- }
-});
-
-</script>
-
-#include browser-sets.inc
-
-#ifdef XP_MACOSX
-#include browser-menubar.inc
-#endif
-
- <popupset id="mainPopupSet">
- <tooltip id="aHTMLTooltip" page="true"/>
- <menupopup id="contentAreaContextMenu" pagemenu="start"
- onpopupshowing="if (event.target != this)
- return true;
- gContextMenu = new nsContextMenu(this, event.shiftKey);
- if (gContextMenu.shouldDisplay)
- document.popupNode = this.triggerNode;
- return gContextMenu.shouldDisplay;"
- onpopuphiding="if (event.target != this)
- return;
- gContextMenu.hiding();
- gContextMenu = null;">
-#include browser-context.inc
- </menupopup>
-
-#include popup-notifications.inc
-
- </popupset>
-
- <commandset id="editMenuCommands"/>
- <chatbox id="chatter" flex="1"/>
-</window>
diff --git a/browser/base/content/nsContextMenu.js b/browser/base/content/nsContextMenu.js
index 4debf1307..e3db24e87 100644
--- a/browser/base/content/nsContextMenu.js
+++ b/browser/base/content/nsContextMenu.js
@@ -148,15 +148,15 @@ nsContextMenu.prototype = {
initNavigationItems: function CM_initNavigationItems() {
var shouldShow = !(this.isContentSelected || this.onLink || this.onImage ||
this.onCanvas || this.onVideo || this.onAudio ||
- this.onTextInput || this.onSocial);
+ this.onTextInput);
this.showItem("context-back", shouldShow);
this.showItem("context-forward", shouldShow);
let stopped = XULBrowserWindow.stopCommand.getAttribute("disabled") == "true";
let stopReloadItem = "";
- if (shouldShow || this.onSocial) {
- stopReloadItem = (stopped || this.onSocial) ? "reload" : "stop";
+ if (shouldShow) {
+ stopReloadItem = stopped ? "reload" : "stop";
}
this.showItem("context-reload", stopReloadItem == "reload");
@@ -217,7 +217,7 @@ nsContextMenu.prototype = {
this.showItem("context-viewsource", shouldShow);
this.showItem("context-viewinfo", shouldShow);
#ifdef MOZ_DEVTOOLS
- var showInspect = !this.onSocial && gPrefService.getBoolPref("devtools.inspector.enabled");
+ var showInspect = gPrefService.getBoolPref("devtools.inspector.enabled");
this.showItem("inspect-separator", showInspect);
this.showItem("context-inspect", showInspect);
#endif
@@ -273,9 +273,9 @@ nsContextMenu.prototype = {
// Use "Bookmark This Link" if on a link.
this.showItem("context-bookmarkpage",
!(this.isContentSelected || this.onTextInput || this.onLink ||
- this.onImage || this.onVideo || this.onAudio || this.onSocial));
- this.showItem("context-bookmarklink", (this.onLink && !this.onMailtoLink &&
- !this.onSocial) || this.onPlainTextLink);
+ this.onImage || this.onVideo || this.onAudio));
+ this.showItem("context-bookmarklink", (this.onLink && !this.onMailtoLink) ||
+ this.onPlainTextLink);
this.showItem("context-searchselect", isTextSelected);
this.showItem("context-keywordfield",
this.onTextInput && this.onKeywordField);
@@ -308,45 +308,6 @@ nsContextMenu.prototype = {
this.onTextInput && top.gBidiUI);
this.showItem("context-bidi-page-direction-toggle",
!this.onTextInput && top.gBidiUI);
-
- // SocialMarks
- let marksEnabled = SocialUI.enabled && Social.provider.pageMarkInfo;
- let enablePageMark = marksEnabled && !(this.isContentSelected ||
- this.onTextInput || this.onLink || this.onImage ||
- this.onVideo || this.onAudio || this.onSocial);
- let enableLinkMark = marksEnabled && ((this.onLink && !this.onMailtoLink &&
- !this.onSocial) || this.onPlainTextLink);
- if (enablePageMark) {
- Social.isURIMarked(gBrowser.currentURI, function(marked) {
- let label = marked ? "social.unmarkpage.label" : "social.markpage.label";
- let provider = Social.provider || Social.defaultProvider;
- let menuLabel = gNavigatorBundle.getFormattedString(label, [provider.name]);
- this.setItemAttr("context-markpage", "label", menuLabel);
- }.bind(this));
- }
- this.showItem("context-markpage", enablePageMark);
- if (enableLinkMark) {
- Social.isURIMarked(this.linkURI, function(marked) {
- let label = marked ? "social.unmarklink.label" : "social.marklink.label";
- let provider = Social.provider || Social.defaultProvider;
- let menuLabel = gNavigatorBundle.getFormattedString(label, [provider.name]);
- this.setItemAttr("context-marklink", "label", menuLabel);
- }.bind(this));
- }
- this.showItem("context-marklink", enableLinkMark);
-
- // SocialShare
- let shareButton = SocialShare.shareButton;
- let shareEnabled = shareButton && !shareButton.disabled && !this.onSocial;
- let pageShare = shareEnabled && !(this.isContentSelected ||
- this.onTextInput || this.onLink || this.onImage ||
- this.onVideo || this.onAudio);
- this.showItem("context-sharepage", pageShare);
- this.showItem("context-shareselect", shareEnabled && this.isContentSelected);
- this.showItem("context-sharelink", shareEnabled && (this.onLink || this.onPlainTextLink) && !this.onMailtoLink);
- this.showItem("context-shareimage", shareEnabled && this.onImage);
- this.showItem("context-sharevideo", shareEnabled && this.onVideo);
- this.setItemAttr("context-sharevideo", "disabled", !this.mediaURL);
},
initSpellingItems: function() {
@@ -547,7 +508,6 @@ nsContextMenu.prototype = {
.getInterface(Ci.nsIWebNavigation)
.QueryInterface(Ci.nsIDocShell)
.chromeEventHandler;
- this.onSocial = !!this.browser.getAttribute("origin");
// Check if we are in a synthetic document (stand alone image, video, etc.).
this.inSyntheticDoc = this.target.ownerDocument.mozSyntheticDocument;
@@ -869,15 +829,7 @@ nsContextMenu.prototype = {
},
reload: function(event) {
- if (this.onSocial) {
- // full reload of social provider
- Social.enabled = false;
- Services.tm.mainThread.dispatch(function() {
- Social.enabled = true;
- }, Components.interfaces.nsIThread.DISPATCH_NORMAL);
- } else {
- BrowserReloadOrDuplicate(event);
- }
+ BrowserReloadOrDuplicate(event);
},
// View Partial Source
@@ -1559,27 +1511,6 @@ nsContextMenu.prototype = {
}
},
- markLink: function CM_markLink() {
- // send link to social
- SocialMark.toggleURIMark(this.linkURI);
- },
-
- shareLink: function CM_shareLink() {
- SocialShare.sharePage(null, { url: this.linkURI.spec });
- },
-
- shareImage: function CM_shareImage() {
- SocialShare.sharePage(null, { url: this.imageURL, previews: [ this.mediaURL ] });
- },
-
- shareVideo: function CM_shareVideo() {
- SocialShare.sharePage(null, { url: this.mediaURL, source: this.mediaURL });
- },
-
- shareSelect: function CM_shareSelect(selection) {
- SocialShare.sharePage(null, { url: this.browser.currentURI.spec, text: selection });
- },
-
savePageAs: function CM_savePageAs() {
saveDocument(this.browser.contentDocument);
},
diff --git a/browser/base/content/socialchat.xml b/browser/base/content/socialchat.xml
deleted file mode 100644
index a4843eefa..000000000
--- a/browser/base/content/socialchat.xml
+++ /dev/null
@@ -1,747 +0,0 @@
-<?xml version="1.0"?>
-
-<bindings id="socialChatBindings"
- xmlns="http://www.mozilla.org/xbl"
- xmlns:xbl="http://www.mozilla.org/xbl"
- xmlns:xul="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
-
- <binding id="chatbox">
- <content orient="vertical" mousethrough="never">
- <xul:hbox class="chat-titlebar" xbl:inherits="minimized,selected,activity" align="baseline">
- <xul:hbox flex="1" onclick="document.getBindingParent(this).onTitlebarClick(event);">
- <xul:image class="chat-status-icon" xbl:inherits="src=image"/>
- <xul:label class="chat-title" flex="1" xbl:inherits="value=label" crop="center"/>
- </xul:hbox>
- <xul:toolbarbutton id="notification-icon" class="notification-anchor-icon chat-toolbarbutton"
- oncommand="document.getBindingParent(this).showNotifications(); event.stopPropagation();"/>
- <xul:toolbarbutton anonid="minimize" class="chat-minimize-button chat-toolbarbutton"
- oncommand="document.getBindingParent(this).toggle();"/>
- <xul:toolbarbutton anonid="swap" class="chat-swap-button chat-toolbarbutton"
- oncommand="document.getBindingParent(this).swapWindows();"/>
- <xul:toolbarbutton anonid="close" class="chat-close-button chat-toolbarbutton"
- oncommand="document.getBindingParent(this).close();"/>
- </xul:hbox>
- <xul:browser anonid="content" class="chat-frame" flex="1"
- context="contentAreaContextMenu"
- disableglobalhistory="true"
- tooltip="aHTMLTooltip"
- xbl:inherits="src,origin" type="content"/>
- </content>
-
- <implementation implements="nsIDOMEventListener">
- <constructor><![CDATA[
- let Social = Components.utils.import("resource:///modules/Social.jsm", {}).Social;
- this.content.__defineGetter__("popupnotificationanchor",
- () => document.getAnonymousElementByAttribute(this, "id", "notification-icon"));
- Social.setErrorListener(this.content, function(aBrowser) {
- aBrowser.webNavigation.loadURI("about:socialerror?mode=compactInfo", null, null, null, null);
- });
- if (!this.chatbar) {
- document.getAnonymousElementByAttribute(this, "anonid", "minimize").hidden = true;
- document.getAnonymousElementByAttribute(this, "anonid", "close").hidden = true;
- }
- let contentWindow = this.contentWindow;
- this.addEventListener("DOMContentLoaded", function DOMContentLoaded(event) {
- if (event.target != this.contentDocument)
- return;
- this.removeEventListener("DOMContentLoaded", DOMContentLoaded, true);
- this.isActive = !this.minimized;
- // process this._callbacks, then set to null so the chatbox creator
- // knows to make new callbacks immediately.
- if (this._callbacks) {
- for (let callback of this._callbacks) {
- if (callback)
- callback(contentWindow);
- }
- this._callbacks = null;
- }
-
- // content can send a socialChatActivity event to have the UI update.
- let chatActivity = function() {
- this.setAttribute("activity", true);
- if (this.chatbar)
- this.chatbar.updateTitlebar(this);
- }.bind(this);
- contentWindow.addEventListener("socialChatActivity", chatActivity);
- contentWindow.addEventListener("unload", function unload() {
- contentWindow.removeEventListener("unload", unload);
- contentWindow.removeEventListener("socialChatActivity", chatActivity);
- });
- }, true);
- if (this.src)
- this.setAttribute("src", this.src);
- ]]></constructor>
-
- <field name="content" readonly="true">
- document.getAnonymousElementByAttribute(this, "anonid", "content");
- </field>
-
- <property name="contentWindow">
- <getter>
- return this.content.contentWindow;
- </getter>
- </property>
-
- <property name="contentDocument">
- <getter>
- return this.content.contentDocument;
- </getter>
- </property>
-
- <property name="minimized">
- <getter>
- return this.getAttribute("minimized") == "true";
- </getter>
- <setter><![CDATA[
- // Note that this.isActive is set via our transitionend handler so
- // the content doesn't see intermediate values.
- let parent = this.chatbar;
- if (val) {
- this.setAttribute("minimized", "true");
- // If this chat is the selected one a new one needs to be selected.
- if (parent && parent.selectedChat == this)
- parent._selectAnotherChat();
- } else {
- this.removeAttribute("minimized");
- // this chat gets selected.
- if (parent)
- parent.selectedChat = this;
- }
- ]]></setter>
- </property>
-
- <property name="chatbar">
- <getter>
- if (this.parentNode.nodeName == "chatbar")
- return this.parentNode;
- return null;
- </getter>
- </property>
-
- <property name="isActive">
- <getter>
- return this.content.docShell.isActive;
- </getter>
- <setter>
- this.content.docShell.isActive = !!val;
-
- // let the chat frame know if it is being shown or hidden
- let evt = this.contentDocument.createEvent("CustomEvent");
- evt.initCustomEvent(val ? "socialFrameShow" : "socialFrameHide", true, true, {});
- this.contentDocument.documentElement.dispatchEvent(evt);
- </setter>
- </property>
-
- <method name="showNotifications">
- <body><![CDATA[
- PopupNotifications._reshowNotifications(this.content.popupnotificationanchor,
- this.content);
- ]]></body>
- </method>
-
- <method name="swapDocShells">
- <parameter name="aTarget"/>
- <body><![CDATA[
- aTarget.setAttribute('label', this.contentDocument.title);
- aTarget.content.setAttribute("origin", this.content.getAttribute("origin"));
- aTarget.content.popupnotificationanchor.className = this.content.popupnotificationanchor.className;
- this.content.socialErrorListener.remove();
- aTarget.content.socialErrorListener.remove();
- this.content.swapDocShells(aTarget.content);
- Social.setErrorListener(this.content, function(aBrowser) {}); // 'this' will be destroyed soon.
- Social.setErrorListener(aTarget.content, function(aBrowser) {
- aBrowser.webNavigation.loadURI("about:socialerror?mode=compactInfo", null, null, null, null);
- });
- ]]></body>
- </method>
-
- <method name="onTitlebarClick">
- <parameter name="aEvent"/>
- <body><![CDATA[
- if (!this.chatbar)
- return;
- if (aEvent.button == 0) { // left-click: toggle minimized.
- this.toggle();
- // if we restored it, we want to focus it.
- if (!this.minimized)
- this.chatbar.focus();
- } else if (aEvent.button == 1) // middle-click: close chat
- this.close();
- ]]></body>
- </method>
-
- <method name="close">
- <body><![CDATA[
- if (this.chatbar)
- this.chatbar.remove(this);
- else
- window.close();
- ]]></body>
- </method>
-
- <method name="swapWindows">
- <body><![CDATA[
- let provider = Social._getProviderFromOrigin(this.content.getAttribute("origin"));
- if (this.chatbar) {
- this.chatbar.detachChatbox(this, { "centerscreen": "yes" }, win => {
- win.document.title = provider.name;
- });
- } else {
- // attach this chatbox to the topmost browser window
- let findChromeWindowForChats = Cu.import("resource://gre/modules/MozSocialAPI.jsm").findChromeWindowForChats;
- let win = findChromeWindowForChats();
- let chatbar = win.SocialChatBar.chatbar;
- chatbar.openChat(provider, "about:blank", win => {
- this.swapDocShells(chatbar.selectedChat);
- chatbar.focus();
- this.close();
- });
- }
- ]]></body>
- </method>
-
- <method name="toggle">
- <body><![CDATA[
- this.minimized = !this.minimized;
- ]]></body>
- </method>
- </implementation>
-
- <handlers>
- <handler event="focus" phase="capturing">
- if (this.chatbar)
- this.chatbar.selectedChat = this;
- </handler>
- <handler event="DOMTitleChanged"><![CDATA[
- this.setAttribute('label', this.contentDocument.title);
- if (this.chatbar)
- this.chatbar.updateTitlebar(this);
- ]]></handler>
- <handler event="DOMLinkAdded"><![CDATA[
- // much of this logic is from DOMLinkHandler in browser.js
- // this sets the presence icon for a chat user, we simply use favicon style updating
- let link = event.originalTarget;
- let rel = link.rel && link.rel.toLowerCase();
- if (!link || !link.ownerDocument || !rel || !link.href)
- return;
- if (link.rel.indexOf("icon") < 0)
- return;
-
- let uri = DOMLinkHandler.getLinkIconURI(link);
- if (!uri)
- return;
-
- // we made it this far, use it
- this.setAttribute('image', uri.spec);
- if (this.chatbar)
- this.chatbar.updateTitlebar(this);
- ]]></handler>
- <handler event="transitionend">
- if (this.isActive == this.minimized)
- this.isActive = !this.minimized;
- </handler>
- </handlers>
- </binding>
-
- <binding id="chatbar">
- <content>
- <xul:hbox align="end" pack="end" anonid="innerbox" class="chatbar-innerbox" mousethrough="always" flex="1">
- <xul:spacer flex="1" anonid="spacer" class="chatbar-overflow-spacer"/>
- <xul:toolbarbutton anonid="nub" class="chatbar-button" type="menu" collapsed="true" mousethrough="never">
- <xul:menupopup anonid="nubMenu" oncommand="document.getBindingParent(this).showChat(event.target.chat)"/>
- </xul:toolbarbutton>
- <children/>
- </xul:hbox>
- </content>
-
- <implementation implements="nsIDOMEventListener">
- <constructor>
- // to avoid reflows we cache the width of the nub.
- this.cachedWidthNub = 0;
- this._selectedChat = null;
- </constructor>
-
- <field name="innerbox" readonly="true">
- document.getAnonymousElementByAttribute(this, "anonid", "innerbox");
- </field>
-
- <field name="menupopup" readonly="true">
- document.getAnonymousElementByAttribute(this, "anonid", "nubMenu");
- </field>
-
- <field name="nub" readonly="true">
- document.getAnonymousElementByAttribute(this, "anonid", "nub");
- </field>
-
- <method name="focus">
- <body><![CDATA[
- if (!this.selectedChat)
- return;
- Services.focus.focusedWindow = this.selectedChat.contentWindow;
- ]]></body>
- </method>
-
- <method name="_isChatFocused">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- // If there are no XBL bindings for the chat it can't be focused.
- if (!aChatbox.content)
- return false;
- let fw = Services.focus.focusedWindow;
- if (!fw)
- return false;
- // We want to see if the focused window is in the subtree below our browser...
- let containingBrowser = fw.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIWebNavigation)
- .QueryInterface(Ci.nsIDocShell)
- .chromeEventHandler;
- return containingBrowser == aChatbox.content;
- ]]></body>
- </method>
-
- <property name="selectedChat">
- <getter><![CDATA[
- return this._selectedChat;
- ]]></getter>
- <setter><![CDATA[
- // this is pretty horrible, but we:
- // * want to avoid doing touching 'selected' attribute when the
- // specified chat is already selected.
- // * remove 'activity' attribute on newly selected tab *even if*
- // newly selected is already selected.
- // * need to handle either current or new being null.
- if (this._selectedChat != val) {
- if (this._selectedChat) {
- this._selectedChat.removeAttribute("selected");
- }
- this._selectedChat = val;
- if (val) {
- this._selectedChat.setAttribute("selected", "true");
- }
- }
- if (val) {
- this._selectedChat.removeAttribute("activity");
- }
- ]]></setter>
- </property>
-
- <field name="menuitemMap">new WeakMap()</field>
- <field name="chatboxForURL">new Map();</field>
-
- <property name="hasCollapsedChildren">
- <getter><![CDATA[
- return !!this.querySelector("[collapsed]");
- ]]></getter>
- </property>
-
- <property name="collapsedChildren">
- <getter><![CDATA[
- // A generator yielding all collapsed chatboxes, in the order in
- // which they should be restored.
- let child = this.lastElementChild;
- while (child) {
- if (child.collapsed)
- yield child;
- child = child.previousElementSibling;
- }
- ]]></getter>
- </property>
-
- <property name="visibleChildren">
- <getter><![CDATA[
- // A generator yielding all non-collapsed chatboxes.
- let child = this.firstElementChild;
- while (child) {
- if (!child.collapsed)
- yield child;
- child = child.nextElementSibling;
- }
- ]]></getter>
- </property>
-
- <property name="collapsibleChildren">
- <getter><![CDATA[
- // A generator yielding all children which are able to be collapsed
- // in the order in which they should be collapsed.
- // (currently this is all visible ones other than the selected one.)
- for (let child of this.visibleChildren)
- if (child != this.selectedChat)
- yield child;
- ]]></getter>
- </property>
-
- <method name="_selectAnotherChat">
- <body><![CDATA[
- // Select a different chat (as the currently selected one is no
- // longer suitable as the selection - maybe it is being minimized or
- // closed.) We only select non-minimized and non-collapsed chats,
- // and if none are found, set the selectedChat to null.
- // It's possible in the future we will track most-recently-selected
- // chats or similar to find the "best" candidate - for now though
- // the choice is somewhat arbitrary.
- let moveFocus = this.selectedChat && this._isChatFocused(this.selectedChat);
- for (let other of this.children) {
- if (other != this.selectedChat && !other.minimized && !other.collapsed) {
- this.selectedChat = other;
- if (moveFocus)
- this.focus();
- return;
- }
- }
- // can't find another - so set no chat as selected.
- this.selectedChat = null;
- ]]></body>
- </method>
-
- <method name="updateTitlebar">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- if (aChatbox.collapsed) {
- let menuitem = this.menuitemMap.get(aChatbox);
- if (aChatbox.getAttribute("activity")) {
- menuitem.setAttribute("activity", true);
- this.nub.setAttribute("activity", true);
- }
- menuitem.setAttribute("label", aChatbox.getAttribute("label"));
- menuitem.setAttribute("image", aChatbox.getAttribute("image"));
- }
- ]]></body>
- </method>
-
- <method name="calcTotalWidthOf">
- <parameter name="aElement"/>
- <body><![CDATA[
- let cs = document.defaultView.getComputedStyle(aElement);
- let margins = parseInt(cs.marginLeft) + parseInt(cs.marginRight);
- return aElement.getBoundingClientRect().width + margins;
- ]]></body>
- </method>
-
- <method name="getTotalChildWidth">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- // These are from the CSS for the chatbox and must be kept in sync.
- // We can't use calcTotalWidthOf due to the transitions...
- const CHAT_WIDTH_OPEN = 260;
- const CHAT_WIDTH_MINIMIZED = 160;
- return aChatbox.minimized ? CHAT_WIDTH_MINIMIZED : CHAT_WIDTH_OPEN;
- ]]></body>
- </method>
-
- <method name="collapseChat">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- // we ensure that the cached width for a child of this type is
- // up-to-date so we can use it when resizing.
- this.getTotalChildWidth(aChatbox);
- aChatbox.collapsed = true;
- aChatbox.isActive = false;
- let menu = document.createElementNS("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul", "menuitem");
- menu.setAttribute("class", "menuitem-iconic");
- menu.setAttribute("label", aChatbox.contentDocument.title);
- menu.setAttribute("image", aChatbox.getAttribute("image"));
- menu.chat = aChatbox;
- this.menuitemMap.set(aChatbox, menu);
- this.menupopup.appendChild(menu);
- this.nub.collapsed = false;
- ]]></body>
- </method>
-
- <method name="showChat">
- <parameter name="aChatbox"/>
- <parameter name="aMode"/>
- <body><![CDATA[
- if ((aMode != "minimized") && aChatbox.minimized)
- aChatbox.minimized = false;
- if (this.selectedChat != aChatbox)
- this.selectedChat = aChatbox;
- if (!aChatbox.collapsed)
- return; // already showing - no more to do.
- this._showChat(aChatbox);
- // showing a collapsed chat might mean another needs to be collapsed
- // to make room...
- this.resize();
- ]]></body>
- </method>
-
- <method name="_showChat">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- // the actual implementation - doesn't check for overflow, assumes
- // collapsed, etc.
- let menuitem = this.menuitemMap.get(aChatbox);
- this.menuitemMap.delete(aChatbox);
- this.menupopup.removeChild(menuitem);
- aChatbox.collapsed = false;
- aChatbox.isActive = !aChatbox.minimized;
- ]]></body>
- </method>
-
- <method name="remove">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- this._remove(aChatbox);
- // The removal of a chat may mean a collapsed one can spring up,
- // or that the popup should be hidden. We also defer the selection
- // of another chat until after a resize, as a new candidate may
- // become uncollapsed after the resize.
- this.resize();
- if (this.selectedChat == aChatbox) {
- this._selectAnotherChat();
- }
- ]]></body>
- </method>
-
- <method name="_remove">
- <parameter name="aChatbox"/>
- <body><![CDATA[
- aChatbox.content.socialErrorListener.remove();
- this.removeChild(aChatbox);
- // child might have been collapsed.
- let menuitem = this.menuitemMap.get(aChatbox);
- if (menuitem) {
- this.menuitemMap.delete(aChatbox);
- this.menupopup.removeChild(menuitem);
- }
- this.chatboxForURL.delete(aChatbox.getAttribute('src'));
- ]]></body>
- </method>
-
- <method name="removeAll">
- <body><![CDATA[
- this.selectedChat = null;
- while (this.firstElementChild) {
- this._remove(this.firstElementChild);
- }
- // and the nub/popup must also die.
- this.nub.collapsed = true;
- ]]></body>
- </method>
-
- <method name="openChat">
- <parameter name="aProvider"/>
- <parameter name="aURL"/>
- <parameter name="aCallback"/>
- <parameter name="aMode"/>
- <body><![CDATA[
- let cb = this.chatboxForURL.get(aURL);
- if (cb) {
- cb = cb.get();
- if (cb.parentNode) {
- this.showChat(cb, aMode);
- if (aCallback) {
- if (cb._callbacks == null) {
- // DOMContentLoaded has already fired, so callback now.
- aCallback(cb.contentWindow);
- } else {
- // DOMContentLoaded for this chat is yet to fire...
- cb._callbacks.push(aCallback);
- }
- }
- return;
- }
- this.chatboxForURL.delete(aURL);
- }
- cb = document.createElementNS("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul", "chatbox");
- // _callbacks is a javascript property instead of a <field> as it
- // must exist before the (possibly delayed) bindings are created.
- cb._callbacks = [aCallback];
- // src also a javascript property; the src attribute is set in the ctor.
- cb.src = aURL;
- if (aMode == "minimized")
- cb.setAttribute("minimized", "true");
- cb.setAttribute("origin", aProvider.origin);
- this.insertBefore(cb, this.firstChild);
- this.selectedChat = cb;
- this.chatboxForURL.set(aURL, Cu.getWeakReference(cb));
- this.resize();
- ]]></body>
- </method>
-
- <method name="resize">
- <body><![CDATA[
- // Checks the current size against the collapsed state of children
- // and collapses or expands as necessary such that as many as possible
- // are shown.
- // So 2 basic strategies:
- // * Collapse/Expand one at a time until we can't collapse/expand any
- // more - but this is one reflow per change.
- // * Calculate the dimensions ourself and choose how many to collapse
- // or expand based on this, then do them all in one go. This is one
- // reflow regardless of how many we change.
- // So we go the more complicated but more efficient second option...
- let availWidth = this.getBoundingClientRect().width;
- let currentWidth = 0;
- if (!this.nub.collapsed) { // the nub is visible.
- if (!this.cachedWidthNub)
- this.cachedWidthNub = this.calcTotalWidthOf(this.nub);
- currentWidth += this.cachedWidthNub;
- }
- for (let child of this.visibleChildren) {
- currentWidth += this.getTotalChildWidth(child);
- }
-
- if (currentWidth > availWidth) {
- // we need to collapse some.
- let toCollapse = [];
- for (let child of this.collapsibleChildren) {
- if (currentWidth <= availWidth)
- break;
- toCollapse.push(child);
- currentWidth -= this.getTotalChildWidth(child);
- }
- if (toCollapse.length) {
- for (let child of toCollapse)
- this.collapseChat(child);
- }
- } else if (currentWidth < availWidth) {
- // we *might* be able to expand some - see how many.
- // XXX - if this was clever, it could know when removing the nub
- // leaves enough space to show all collapsed
- let toShow = [];
- for (let child of this.collapsedChildren) {
- currentWidth += this.getTotalChildWidth(child);
- if (currentWidth > availWidth)
- break;
- toShow.push(child);
- }
- for (let child of toShow)
- this._showChat(child);
-
- // If none remain collapsed remove the nub.
- if (!this.hasCollapsedChildren) {
- this.nub.collapsed = true;
- }
- }
- // else: achievement unlocked - we are pixel-perfect!
- ]]></body>
- </method>
-
- <method name="handleEvent">
- <parameter name="aEvent"/>
- <body><![CDATA[
- if (aEvent.type == "resize" && aEvent.eventPhase == aEvent.BUBBLING_PHASE) {
- this.resize();
- }
- ]]></body>
- </method>
-
- <method name="_getDragTarget">
- <parameter name="event"/>
- <body><![CDATA[
- return event.target.localName == "chatbox" ? event.target : null;
- ]]></body>
- </method>
-
- <!-- Moves a chatbox to a new window. -->
- <method name="detachChatbox">
- <parameter name="aChatbox"/>
- <parameter name="aOptions"/>
- <parameter name="aCallback"/>
- <body><![CDATA[
- let options = "";
- for (let name in aOptions)
- options += "," + name + "=" + aOptions[name];
-
- let otherWin = window.openDialog("chrome://browser/content/chatWindow.xul", null, "chrome,all" + options);
-
- otherWin.addEventListener("load", function _chatLoad(event) {
- if (event.target != otherWin.document)
- return;
-
- otherWin.removeEventListener("load", _chatLoad, true);
- let otherChatbox = otherWin.document.getElementById("chatter");
- aChatbox.swapDocShells(otherChatbox);
- aChatbox.close();
- if (aCallback)
- aCallback(otherWin);
- }, true);
- ]]></body>
- </method>
-
- </implementation>
-
- <handlers>
- <handler event="popupshown"><![CDATA[
- this.nub.removeAttribute("activity");
- ]]></handler>
- <handler event="load"><![CDATA[
- window.addEventListener("resize", this);
- ]]></handler>
- <handler event="unload"><![CDATA[
- window.removeEventListener("resize", this);
- ]]></handler>
-
- <handler event="dragstart"><![CDATA[
- // chat window dragging is essentially duplicated from tabbrowser.xml
- // to acheive the same visual experience
- let chatbox = this._getDragTarget(event);
- if (!chatbox) {
- return;
- }
-
- let dt = event.dataTransfer;
- // we do not set a url in the drag data to prevent moving to tabbrowser
- // or otherwise having unexpected drop handlers do something with our
- // chatbox
- dt.mozSetDataAt("application/x-moz-chatbox", chatbox, 0);
-
- // Set the cursor to an arrow during tab drags.
- dt.mozCursor = "default";
-
- // Create a canvas to which we capture the current tab.
- // Until canvas is HiDPI-aware (bug 780362), we need to scale the desired
- // canvas size (in CSS pixels) to the window's backing resolution in order
- // to get a full-resolution drag image for use on HiDPI displays.
- let windowUtils = window.getInterface(Ci.nsIDOMWindowUtils);
- let scale = windowUtils.screenPixelsPerCSSPixel / windowUtils.fullZoom;
- let canvas = document.createElementNS("http://www.w3.org/1999/xhtml", "canvas");
- canvas.mozOpaque = true;
- canvas.width = 160 * scale;
- canvas.height = 90 * scale;
- PageThumbs.captureToCanvas(chatbox.contentWindow, canvas);
- dt.setDragImage(canvas, -16 * scale, -16 * scale);
-
- event.stopPropagation();
- ]]></handler>
-
- <handler event="dragend"><![CDATA[
- let dt = event.dataTransfer;
- let draggedChat = dt.mozGetDataAt("application/x-moz-chatbox", 0);
- if (dt.mozUserCancelled || dt.dropEffect != "none") {
- return;
- }
-
- let eX = event.screenX;
- let eY = event.screenY;
- // screen.availLeft et. al. only check the screen that this window is on,
- // but we want to look at the screen the tab is being dropped onto.
- let sX = {}, sY = {}, sWidth = {}, sHeight = {};
- Cc["@mozilla.org/gfx/screenmanager;1"]
- .getService(Ci.nsIScreenManager)
- .screenForRect(eX, eY, 1, 1)
- .GetAvailRect(sX, sY, sWidth, sHeight);
- // default size for the chat window as used in chatWindow.xul, use them
- // here to attempt to keep the window fully within the screen when
- // opening at the drop point. If the user has resized the window to
- // something larger (which gets persisted), at least a good portion of
- // the window should still be within the screen.
- let winWidth = 400;
- let winHeight = 420;
- // ensure new window entirely within screen
- let left = Math.min(Math.max(eX, sX.value),
- sX.value + sWidth.value - winWidth);
- let top = Math.min(Math.max(eY, sY.value),
- sY.value + sHeight.value - winHeight);
-
- let provider = Social._getProviderFromOrigin(draggedChat.content.getAttribute("origin"));
- this.detachChatbox(draggedChat, { screenX: left, screenY: top }, win => {
- win.document.title = provider.name;
- });
-
- event.stopPropagation();
- ]]></handler>
- </handlers>
- </binding>
-
-</bindings>
diff --git a/browser/base/jar.mn b/browser/base/jar.mn
index 1ecb96eb5..8652a96b9 100644
--- a/browser/base/jar.mn
+++ b/browser/base/jar.mn
@@ -54,7 +54,6 @@ browser.jar:
#endif
content/browser/aboutRobots-icon.png (content/aboutRobots-icon.png)
content/browser/aboutRobots-widget-left.png (content/aboutRobots-widget-left.png)
- content/browser/aboutSocialError.xhtml (content/aboutSocialError.xhtml)
* content/browser/browser.css (content/browser.css)
content/browser/browser-menudragging.xul (content/browser-menudragging.xul)
content/browser/browser-menudragging.js (content/browser-menudragging.js)
@@ -62,7 +61,6 @@ browser.jar:
* content/browser/browser.js (content/browser.js)
* content/browser/browser.xul (content/browser.xul)
* content/browser/browser-tabPreviews.xml (content/browser-tabPreviews.xml)
-* content/browser/chatWindow.xul (content/chatWindow.xul)
content/browser/content.js (content/content.js)
content/browser/imagedocument.png (content/imagedocument.png)
* content/browser/padlock.xul (content/padlock.xul)
@@ -135,7 +133,6 @@ browser.jar:
#ifdef XP_WIN
content/browser/win6BrowserOverlay.xul (content/win6BrowserOverlay.xul)
#endif
- content/browser/socialchat.xml (content/socialchat.xml)
# the following files are browser-specific overrides
* content/browser/license.html (/toolkit/content/license.html)
% override chrome://global/content/license.html chrome://browser/content/license.html
diff --git a/browser/branding/official/pref/firefox-branding.js b/browser/branding/official/pref/firefox-branding.js
index 1f4b062e1..9819eb0a4 100644
--- a/browser/branding/official/pref/firefox-branding.js
+++ b/browser/branding/official/pref/firefox-branding.js
@@ -102,8 +102,6 @@ pref("browser.identity.ssl_domain_display", 1); //show domain verified SSL (blue
pref("browser.urlbar.autoFill", true);
pref("browser.urlbar.autoFill.typed", true);
-pref("social.enabled", false);
-
//Set tabs NOT on top
pref("browser.tabs.onTop",false);
diff --git a/browser/branding/unofficial/pref/firefox-branding.js b/browser/branding/unofficial/pref/firefox-branding.js
index 211283266..e43cbcb96 100644
--- a/browser/branding/unofficial/pref/firefox-branding.js
+++ b/browser/branding/unofficial/pref/firefox-branding.js
@@ -83,8 +83,6 @@ pref("browser.identity.ssl_domain_display", 1); //show domain verified SSL (blue
pref("browser.urlbar.autoFill", true);
pref("browser.urlbar.autoFill.typed", true);
-pref("social.enabled", false);
-
//Set tabs NOT on top
pref("browser.tabs.onTop",false);
diff --git a/browser/components/about/AboutRedirector.cpp b/browser/components/about/AboutRedirector.cpp
index 8695534b6..a5f30f7d7 100644
--- a/browser/components/about/AboutRedirector.cpp
+++ b/browser/components/about/AboutRedirector.cpp
@@ -41,9 +41,6 @@ static RedirEntry kRedirMap[] = {
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT |
nsIAboutModule::ALLOW_SCRIPT |
nsIAboutModule::HIDE_FROM_ABOUTABOUT },
- { "socialerror", "chrome://browser/content/aboutSocialError.xhtml",
- nsIAboutModule::ALLOW_SCRIPT |
- nsIAboutModule::HIDE_FROM_ABOUTABOUT },
{ "feeds", "chrome://browser/content/feeds/subscribe.xhtml",
nsIAboutModule::URI_SAFE_FOR_UNTRUSTED_CONTENT |
nsIAboutModule::ALLOW_SCRIPT |
diff --git a/browser/locales/en-US/chrome/browser/browser.dtd b/browser/locales/en-US/chrome/browser/browser.dtd
index 03191d1d7..42a955931 100644
--- a/browser/locales/en-US/chrome/browser/browser.dtd
+++ b/browser/locales/en-US/chrome/browser/browser.dtd
@@ -118,17 +118,6 @@ These should match what Safari and other Apple applications use on OS X Lion. --
<!ENTITY bookmarkThisPageCmd.label "Bookmark This Page">
<!ENTITY bookmarkThisPageCmd.commandkey "d">
<!ENTITY markPageCmd.commandkey "l">
-<!ENTITY sharePageCmd.label "Share This Page">
-<!ENTITY sharePageCmd.commandkey "S">
-<!ENTITY sharePageCmd.accesskey "s">
-<!ENTITY shareLinkCmd.label "Share This Link">
-<!ENTITY shareLinkCmd.accesskey "s">
-<!ENTITY shareImageCmd.label "Share This Image">
-<!ENTITY shareImageCmd.accesskey "s">
-<!ENTITY shareSelectCmd.label "Share Selection">
-<!ENTITY shareSelectCmd.accesskey "s">
-<!ENTITY shareVideoCmd.label "Share This Video">
-<!ENTITY shareVideoCmd.accesskey "s">
<!ENTITY subscribeToPageMenupopup.label "Subscribe to This Page">
<!ENTITY subscribeToPageMenuitem.label "Subscribe to This Page…">
<!ENTITY addCurPagesCmd.label "Bookmark All Tabs…">
@@ -631,35 +620,6 @@ just addresses the organization to follow, e.g. "This site is run by " -->
<!ENTITY addonBarCloseButton.tooltip "Close Add-on Bar">
<!ENTITY toggleAddonBarCmd.key "/">
-<!ENTITY socialToolbar.title "Social Toolbar Button">
-<!ENTITY social.notLoggedIn.label "Not logged in">
-
-<!ENTITY social.ok.label "OK">
-<!ENTITY social.ok.accesskey "O">
-
-<!ENTITY social.toggleSidebar.label "Show sidebar">
-<!ENTITY social.toggleSidebar.accesskey "s">
-
-<!ENTITY social.addons.label "Manage Services…">
-
-<!ENTITY social.toggleNotifications.label "Show desktop notifications">
-<!ENTITY social.toggleNotifications.accesskey "n">
-
-<!ENTITY social.activated.description "Services from <label/> have been enabled. You can change your settings for services in the <label class='text-link'>Add-on Manager</label>.">
-<!ENTITY social.activated.undo.label "Oops, undo this!">
-<!ENTITY social.activated.undo.accesskey "U">
-<!ENTITY social.learnMore.label "Learn more…">
-<!ENTITY social.learnMore.accesskey "l">
-<!ENTITY social.closeNotificationItem.label "Not Now">
-
-<!ENTITY social.chatBar.commandkey "c">
-<!ENTITY social.chatBar.label "Focus chats">
-<!ENTITY social.chatBar.accesskey "c">
-
-<!-- labels are set dynamically, see browser.properties -->
-<!ENTITY social.markpage.accesskey "m">
-<!ENTITY social.marklink.accesskey "M">
-
<!ENTITY getUserMedia.selectCamera.label "Camera to share:">
<!ENTITY getUserMedia.selectCamera.accesskey "C">
<!ENTITY getUserMedia.selectMicrophone.label "Microphone to share:">
diff --git a/browser/locales/en-US/chrome/browser/browser.properties b/browser/locales/en-US/chrome/browser/browser.properties
index 25cc51ff9..f3b7986ba 100644
--- a/browser/locales/en-US/chrome/browser/browser.properties
+++ b/browser/locales/en-US/chrome/browser/browser.properties
@@ -392,39 +392,6 @@ fullscreen.entered=%S is now fullscreen.
# LOCALIZATION NOTE (fullscreen.rememberDecision): displayed when we enter HTML5 fullscreen mode, %S is the domain name of the focused website (e.g. mozilla.com).
fullscreen.rememberDecision=Remember decision for %S
-service.toolbarbutton.label=Services
-service.toolbarbutton.tooltiptext=Services
-
-# LOCALIZATION NOTE (social.install.description): %1$S is the hostname of the social provider, %2$S is brandShortName (e.g. Firefox)
-service.install.description=Would you like to enable services from %1$S to display in your %2$S toolbar and sidebar?
-service.install.ok.label=Enable Services
-service.install.ok.accesskey=E
-service.install.learnmore=Learn More…
-
-# LOCALIZATION NOTE (social.turnOff.label): %S is the name of the social provider
-social.turnOff.label=Turn off %S
-social.turnOff.accesskey=T
-# LOCALIZATION NOTE (social.turnOn.label): %S is the name of the social provider
-social.turnOn.label=Turn on %S
-social.turnOn.accesskey=T
-
-# LOCALIZATION NOTE (social.markpage.label): %S is the name of the social provider
-social.markpage.label=Send Page to %S
-social.unmarkpage.label=Remove Page from %S
-# LOCALIZATION NOTE (social.marklink.label): %S is the name of the social provider
-social.marklink.label=Send Link to %S
-social.unmarklink.label=Remove Link from %S
-
-# LOCALIZATION NOTE (social.error.message): %1$S is brandShortName (e.g. Firefox), %2$S is the name of the social provider
-social.error.message=%1$S is unable to connect with %2$S right now.
-social.error.tryAgain.label=Try Again
-social.error.tryAgain.accesskey=T
-social.error.closeSidebar.label=Close This Sidebar
-social.error.closeSidebar.accesskey=C
-
-# LOCALIZATION NOTE: %1$S is the label for the toolbar button, %2$S is the associated badge numbering that the social provider may provide.
-social.aria.toolbarButtonBadgeText=%1$S (%2$S)
-
# Identity notifications popups
identity.termsOfService = Terms of Service
identity.privacyPolicy = Privacy Policy
diff --git a/browser/modules/Makefile.in b/browser/modules/Makefile.in
index 983a3c91e..d9cec6a79 100644
--- a/browser/modules/Makefile.in
+++ b/browser/modules/Makefile.in
@@ -19,7 +19,6 @@ EXTRA_JS_MODULES = \
SignInToWebsite.jsm \
webappsUI.jsm \
webrtcUI.jsm \
- Social.jsm \
SharedFrame.jsm \
$(NULL)
diff --git a/browser/modules/Social.jsm b/browser/modules/Social.jsm
deleted file mode 100644
index d1beb9398..000000000
--- a/browser/modules/Social.jsm
+++ /dev/null
@@ -1,583 +0,0 @@
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this file,
- * You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-"use strict";
-
-this.EXPORTED_SYMBOLS = ["Social", "OpenGraphBuilder"];
-
-const Ci = Components.interfaces;
-const Cc = Components.classes;
-const Cu = Components.utils;
-
-Cu.import("resource://gre/modules/Services.jsm");
-Cu.import("resource://gre/modules/XPCOMUtils.jsm");
-
-XPCOMUtils.defineLazyModuleGetter(this, "SocialService",
- "resource://gre/modules/SocialService.jsm");
-XPCOMUtils.defineLazyModuleGetter(this, "PlacesUtils",
- "resource://gre/modules/PlacesUtils.jsm");
-XPCOMUtils.defineLazyModuleGetter(this, "Promise",
- "resource://gre/modules/commonjs/sdk/core/promise.js");
-
-XPCOMUtils.defineLazyServiceGetter(this, "unescapeService",
- "@mozilla.org/feed-unescapehtml;1",
- "nsIScriptableUnescapeHTML");
-
-// Add a pref observer for the enabled state
-function prefObserver(subject, topic, data) {
- let enable = Services.prefs.getBoolPref("social.enabled");
- if (enable && !Social.provider) {
- Social.provider = Social.defaultProvider;
- } else if (!enable && Social.provider) {
- Social.provider = null;
- }
-}
-
-Services.prefs.addObserver("social.enabled", prefObserver, false);
-Services.obs.addObserver(function xpcomShutdown() {
- Services.obs.removeObserver(xpcomShutdown, "xpcom-shutdown");
- Services.prefs.removeObserver("social.enabled", prefObserver);
-}, "xpcom-shutdown", false);
-
-function promiseSetAnnotation(aURI, providerList) {
- let deferred = Promise.defer();
-
- // Delaying to catch issues with asynchronous behavior while waiting
- // to implement asynchronous annotations in bug 699844.
- Services.tm.mainThread.dispatch(function() {
- try {
- if (providerList && providerList.length > 0) {
- PlacesUtils.annotations.setPageAnnotation(
- aURI, "social/mark", JSON.stringify(providerList), 0,
- PlacesUtils.annotations.EXPIRE_WITH_HISTORY);
- } else {
- PlacesUtils.annotations.removePageAnnotation(aURI, "social/mark");
- }
- } catch(e) {
- Cu.reportError("SocialAnnotation failed: " + e);
- }
- deferred.resolve();
- }, Ci.nsIThread.DISPATCH_NORMAL);
-
- return deferred.promise;
-}
-
-function promiseGetAnnotation(aURI) {
- let deferred = Promise.defer();
-
- // Delaying to catch issues with asynchronous behavior while waiting
- // to implement asynchronous annotations in bug 699844.
- Services.tm.mainThread.dispatch(function() {
- let val = null;
- try {
- val = PlacesUtils.annotations.getPageAnnotation(aURI, "social/mark");
- } catch (ex) { }
-
- deferred.resolve(val);
- }, Ci.nsIThread.DISPATCH_NORMAL);
-
- return deferred.promise;
-}
-
-this.Social = {
- initialized: false,
- lastEventReceived: 0,
- providers: null,
- _disabledForSafeMode: false,
-
- get _currentProviderPref() {
- try {
- return Services.prefs.getComplexValue("social.provider.current",
- Ci.nsISupportsString).data;
- } catch (ex) {}
- return null;
- },
- set _currentProviderPref(val) {
- let string = Cc["@mozilla.org/supports-string;1"].
- createInstance(Ci.nsISupportsString);
- string.data = val;
- Services.prefs.setComplexValue("social.provider.current",
- Ci.nsISupportsString, string);
- },
-
- _provider: null,
- get provider() {
- return this._provider;
- },
- set provider(val) {
- this._setProvider(val);
- },
-
- // Sets the current provider and enables it. Also disables the
- // previously set provider, and notifies observers of the change.
- _setProvider: function (provider) {
- if (this._provider == provider)
- return;
-
- // Disable the previous provider, if any, since we want only one provider to
- // be enabled at once.
- if (this._provider) {
- this._provider.enabled = false;
- this.closeChatWindows();
- }
-
- this._provider = provider;
-
- if (this._provider) {
- this._provider.enabled = true;
- this._currentProviderPref = this._provider.origin;
- }
- let enabled = !!provider;
- if (enabled != SocialService.enabled) {
- SocialService.enabled = enabled;
- Services.prefs.setBoolPref("social.enabled", enabled);
- }
-
- let origin = this._provider && this._provider.origin;
- Services.obs.notifyObservers(null, "social:provider-set", origin);
- },
-
- get defaultProvider() {
- if (this.providers.length == 0)
- return null;
- let provider = this._getProviderFromOrigin(this._currentProviderPref);
- return provider || this.providers[0];
- },
-
- init: function Social_init() {
- this._disabledForSafeMode = Services.appinfo.inSafeMode && this.enabled;
-
- if (this.initialized) {
- return;
- }
- this.initialized = true;
-
- // Retrieve the current set of providers, and set the current provider.
- SocialService.getOrderedProviderList(function (providers) {
- this._updateProviderCache(providers);
- }.bind(this));
-
- // Register an observer for changes to the provider list
- SocialService.registerProviderListener(function providerListener(topic, data) {
- // An engine change caused by adding/removing a provider should notify
- if (topic == "provider-added" || topic == "provider-removed") {
- this._updateProviderCache(data);
- Services.obs.notifyObservers(null, "social:providers-changed", null);
- return;
- }
- if (topic == "provider-update") {
- // a provider has self-updated its manifest, we need to update our
- // cache and possibly reload if it was the current provider.
- let provider = data;
- SocialService.getOrderedProviderList(function(providers) {
- Social._updateProviderCache(providers);
- Services.obs.notifyObservers(null, "social:providers-changed", null);
- // if we need a reload, do it now
- if (provider.enabled) {
- Social.enabled = false;
- Services.tm.mainThread.dispatch(function() {
- Social.enabled = true;
- }, Components.interfaces.nsIThread.DISPATCH_NORMAL);
- }
- });
- }
- }.bind(this));
- },
-
- // Called to update our cache of providers and set the current provider
- _updateProviderCache: function (providers) {
- this.providers = providers;
-
- // If social is currently disabled there's nothing else to do other than
- // to notify about the lack of a provider.
- if (!SocialService.enabled) {
- Services.obs.notifyObservers(null, "social:provider-set", null);
- return;
- }
- // Otherwise set the provider.
- this._setProvider(this.defaultProvider);
- },
-
- set enabled(val) {
- // Setting .enabled is just a shortcut for setting the provider to either
- // the default provider or null...
- if (val) {
- if (!this.provider)
- this.provider = this.defaultProvider;
- } else {
- this.provider = null;
- }
- },
- get enabled() {
- return this.provider != null;
- },
-
- closeChatWindows: function() {
- // close all windows of type Social:Chat
- let windows = Services.wm.getEnumerator("Social:Chat");
- while (windows.hasMoreElements()) {
- let win = windows.getNext();
- win.close();
- }
- },
-
- toggle: function Social_toggle() {
- this.enabled = this._disabledForSafeMode ? false : !this.enabled;
- this._disabledForSafeMode = false;
- },
-
- toggleSidebar: function SocialSidebar_toggle() {
- let prefValue = Services.prefs.getBoolPref("social.sidebar.open");
- Services.prefs.setBoolPref("social.sidebar.open", !prefValue);
- },
-
- toggleNotifications: function SocialNotifications_toggle() {
- let prefValue = Services.prefs.getBoolPref("social.toast-notifications.enabled");
- Services.prefs.setBoolPref("social.toast-notifications.enabled", !prefValue);
- },
-
- haveLoggedInUser: function () {
- return !!(this.provider && this.provider.profile && this.provider.profile.userName);
- },
-
- setProviderByOrigin: function (origin) {
- this.provider = this._getProviderFromOrigin(origin);
- },
-
- _getProviderFromOrigin: function (origin) {
- for (let p of this.providers) {
- if (p.origin == origin) {
- return p;
- }
- }
- return null;
- },
-
- installProvider: function(doc, data, installCallback) {
- SocialService.installProvider(doc, data, installCallback);
- },
-
- uninstallProvider: function(origin, aCallback) {
- SocialService.uninstallProvider(origin, aCallback);
- },
-
- // Activation functionality
- activateFromOrigin: function (origin, callback) {
- // For now only "builtin" providers can be activated. It's OK if the
- // provider has already been activated - we still get called back with it.
- SocialService.addBuiltinProvider(origin, function(provider) {
- if (provider) {
- // No need to activate again if we're already active
- if (provider == this.provider)
- return;
- this.provider = provider;
- }
- if (callback)
- callback(provider);
- }.bind(this));
- },
-
- deactivateFromOrigin: function (origin, oldOrigin) {
- // if we have the old provider, always set that before trying removal
- let provider = this._getProviderFromOrigin(origin);
- let oldProvider = this._getProviderFromOrigin(oldOrigin);
- if (!oldProvider && this.providers.length)
- oldProvider = this.providers[0];
- this.provider = oldProvider;
- if (provider)
- SocialService.removeProvider(origin);
- },
-
- // Page Marking functionality
- _getMarkablePageUrl: function Social_getMarkablePageUrl(aURI) {
- let uri = aURI.clone();
- try {
- // Setting userPass on about:config throws.
- uri.userPass = "";
- } catch (e) {}
- return uri.spec;
- },
-
- isURIMarked: function(aURI, aCallback) {
- promiseGetAnnotation(aURI).then(function(val) {
- if (val) {
- let providerList = JSON.parse(val);
- val = providerList.indexOf(this.provider.origin) >= 0;
- }
- aCallback(!!val);
- }.bind(this));
- },
-
- markURI: function(aURI, aCallback) {
- // this should not be called if this.provider or the port is null
- if (!this.provider) {
- Cu.reportError("Can't mark a page when no provider is current");
- return;
- }
- let port = this.provider.getWorkerPort();
- if (!port) {
- Cu.reportError("Can't mark page as no provider port is available");
- return;
- }
-
- // update or set our annotation
- promiseGetAnnotation(aURI).then(function(val) {
-
- let providerList = val ? JSON.parse(val) : [];
- let marked = providerList.indexOf(this.provider.origin) >= 0;
- if (marked)
- return;
- providerList.push(this.provider.origin);
- // we allow marking links in a page that may not have been visited yet.
- // make sure there is a history entry for the uri, then annotate it.
- let place = {
- uri: aURI,
- visits: [{
- visitDate: Date.now() + 1000,
- transitionType: Ci.nsINavHistoryService.TRANSITION_LINK
- }]
- };
- PlacesUtils.asyncHistory.updatePlaces(place, {
- handleError: function () Cu.reportError("couldn't update history for socialmark annotation"),
- handleResult: function () {},
- handleCompletion: function () {
- promiseSetAnnotation(aURI, providerList).then();
- // post to the provider
- let url = this._getMarkablePageUrl(aURI);
- port.postMessage({
- topic: "social.page-mark",
- data: { url: url, 'marked': true }
- });
- port.close();
- if (aCallback)
- schedule(function() { aCallback(true); } );
- }.bind(this)
- });
- }.bind(this));
- },
-
- unmarkURI: function(aURI, aCallback) {
- // this should not be called if this.provider or the port is null
- if (!this.provider) {
- Cu.reportError("Can't mark a page when no provider is current");
- return;
- }
- let port = this.provider.getWorkerPort();
- if (!port) {
- Cu.reportError("Can't mark page as no provider port is available");
- return;
- }
-
- // set our annotation
- promiseGetAnnotation(aURI).then(function(val) {
- let providerList = val ? JSON.parse(val) : [];
- let marked = providerList.indexOf(this.provider.origin) >= 0;
- if (marked) {
- // remove the annotation
- providerList.splice(providerList.indexOf(this.provider.origin), 1);
- promiseSetAnnotation(aURI, providerList).then();
- }
- // post to the provider regardless
- let url = this._getMarkablePageUrl(aURI);
- port.postMessage({
- topic: "social.page-mark",
- data: { url: url, 'marked': false }
- });
- port.close();
- if (aCallback)
- schedule(function() { aCallback(false); } );
- }.bind(this));
- },
-
- setErrorListener: function(iframe, errorHandler) {
- if (iframe.socialErrorListener)
- return iframe.socialErrorListener;
- return new SocialErrorListener(iframe, errorHandler);
- }
-};
-
-function schedule(callback) {
- Services.tm.mainThread.dispatch(callback, Ci.nsIThread.DISPATCH_NORMAL);
-}
-
-
-// Error handling class used to listen for network errors in the social frames
-// and replace them with a social-specific error page
-function SocialErrorListener(iframe, errorHandler) {
- this.setErrorMessage = errorHandler;
- this.iframe = iframe;
- iframe.socialErrorListener = this;
- iframe.docShell.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIWebProgress)
- .addProgressListener(this,
- Ci.nsIWebProgress.NOTIFY_STATE_REQUEST |
- Ci.nsIWebProgress.NOTIFY_LOCATION);
-}
-
-SocialErrorListener.prototype = {
- QueryInterface: XPCOMUtils.generateQI([Ci.nsIWebProgressListener,
- Ci.nsISupportsWeakReference,
- Ci.nsISupports]),
-
- remove: function() {
- this.iframe.docShell.QueryInterface(Ci.nsIInterfaceRequestor)
- .getInterface(Ci.nsIWebProgress)
- .removeProgressListener(this);
- delete this.iframe.socialErrorListener;
- },
-
- onStateChange: function SPL_onStateChange(aWebProgress, aRequest, aState, aStatus) {
- let failure = false;
- if ((aState & Ci.nsIWebProgressListener.STATE_STOP)) {
- if (aRequest instanceof Ci.nsIHttpChannel) {
- try {
- // Change the frame to an error page on 4xx (client errors)
- // and 5xx (server errors)
- failure = aRequest.responseStatus >= 400 &&
- aRequest.responseStatus < 600;
- } catch (e) {}
- }
- }
-
- // Calling cancel() will raise some OnStateChange notifications by itself,
- // so avoid doing that more than once
- if (failure && aStatus != Components.results.NS_BINDING_ABORTED) {
- aRequest.cancel(Components.results.NS_BINDING_ABORTED);
- Social.provider.errorState = "content-error";
- this.setErrorMessage(aWebProgress.QueryInterface(Ci.nsIDocShell)
- .chromeEventHandler);
- }
- },
-
- onLocationChange: function SPL_onLocationChange(aWebProgress, aRequest, aLocation, aFlags) {
- let failure = aFlags & Ci.nsIWebProgressListener.LOCATION_CHANGE_ERROR_PAGE;
- if (failure && Social.provider.errorState != "frameworker-error") {
- aRequest.cancel(Components.results.NS_BINDING_ABORTED);
- Social.provider.errorState = "content-error";
- schedule(function() {
- this.setErrorMessage(aWebProgress.QueryInterface(Ci.nsIDocShell)
- .chromeEventHandler);
- }.bind(this));
- }
- },
-
- onProgressChange: function SPL_onProgressChange() {},
- onStatusChange: function SPL_onStatusChange() {},
- onSecurityChange: function SPL_onSecurityChange() {},
-};
-
-
-this.OpenGraphBuilder = {
- getData: function(browser) {
- let res = {
- url: this._validateURL(browser, browser.currentURI.spec),
- title: browser.contentDocument.title,
- previews: []
- };
- this._getMetaData(browser, res);
- this._getLinkData(browser, res);
- this._getPageData(browser, res);
- return res;
- },
-
- _getMetaData: function(browser, o) {
- // query for standardized meta data
- let els = browser.contentDocument
- .querySelectorAll("head > meta[property], head > meta[name]");
- if (els.length < 1)
- return;
- let url;
- for (let el of els) {
- let value = el.getAttribute("content")
- if (!value)
- continue;
- value = unescapeService.unescape(value.trim());
- switch (el.getAttribute("property") || el.getAttribute("name")) {
- case "title":
- case "og:title":
- o.title = value;
- break;
- case "description":
- case "og:description":
- o.description = value;
- break;
- case "og:site_name":
- o.siteName = value;
- break;
- case "medium":
- case "og:type":
- o.medium = value;
- break;
- case "og:video":
- url = this._validateURL(browser, value);
- if (url)
- o.source = url;
- break;
- case "og:url":
- url = this._validateURL(browser, value);
- if (url)
- o.url = url;
- break;
- case "og:image":
- url = this._validateURL(browser, value);
- if (url)
- o.previews.push(url);
- break;
- }
- }
- },
-
- _getLinkData: function(browser, o) {
- let els = browser.contentDocument
- .querySelectorAll("head > link[rel], head > link[id]");
- for (let el of els) {
- let url = el.getAttribute("href");
- if (!url)
- continue;
- url = this._validateURL(browser, unescapeService.unescape(url.trim()));
- switch (el.getAttribute("rel") || el.getAttribute("id")) {
- case "shorturl":
- case "shortlink":
- o.shortUrl = url;
- break;
- case "canonicalurl":
- case "canonical":
- o.url = url;
- break;
- case "image_src":
- o.previews.push(url);
- break;
- }
- }
- },
-
- // scrape through the page for data we want
- _getPageData: function(browser, o) {
- if (o.previews.length < 1)
- o.previews = this._getImageUrls(browser);
- },
-
- _validateURL: function(browser, url) {
- let uri = Services.io.newURI(browser.currentURI.resolve(url), null, null);
- if (["http", "https", "ftp", "ftps"].indexOf(uri.scheme) < 0)
- return null;
- uri.userPass = "";
- return uri.spec;
- },
-
- _getImageUrls: function(browser) {
- let l = [];
- let els = browser.contentDocument.querySelectorAll("img");
- for (let el of els) {
- let content = el.getAttribute("src");
- if (content) {
- l.push(this._validateURL(browser, unescapeService.unescape(content)));
- // we don't want a billion images
- if (l.length > 5)
- break;
- }
- }
- return l;
- }
-};
diff --git a/browser/themes/linux/aboutSocialError.css b/browser/themes/linux/aboutSocialError.css
deleted file mode 100644
index d1a9ad53c..000000000
--- a/browser/themes/linux/aboutSocialError.css
+++ /dev/null
@@ -1,98 +0,0 @@
-body {
- background-color: rgb(241, 244, 248);
- margin-top: 2em;
- font: message-box;
- font-size: 100%;
-}
-
-p {
- font-size: .8em;
-}
-
-#error-box {
- background: url('chrome://global/skin/icons/information-24.png') no-repeat left 4px;
- -moz-padding-start: 30px;
-}
-
-#error-box:-moz-locale-dir(rtl) {
- background-position: right 4px;
-}
-
-#main-error-msg {
- color: #4b4b4b;
- font-weight: bold;
-}
-
-
-#button-box {
- text-align: center;
- width: 75%;
- margin: 0 auto;
-}
-
-@media all and (min-width: 300px) {
- #error-box {
- max-width: 50%;
- margin: 0 auto;
- background-image: url('chrome://global/skin/icons/information-32.png');
- min-height: 36px;
- -moz-padding-start: 38px;
- }
-
- button {
- width: auto !important;
- min-width: 150px;
- }
-}
-
-@media all and (min-width: 780px) {
- #error-box {
- max-width: 30%;
- }
-}
-
-button {
- font: message-box;
- font-size: 0.6875em;
- -moz-appearance: none;
- -moz-user-select: none;
- width: 100%;
- margin: 2px 0;
- padding: 2px 6px;
- line-height: 1.2;
- background-color: hsla(210,30%,95%,.1);
- background-image: linear-gradient(hsla(0,0%,100%,.6), hsla(0,0%,100%,.1));
- background-clip: padding-box;
- border: 1px solid hsla(210,15%,25%,.4);
- border-color: hsla(210,15%,25%,.3) hsla(210,15%,25%,.35) hsla(210,15%,25%,.4);
- border-radius: 3px;
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1);
-
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-
-}
-
-button:hover {
- background-color: hsla(210,30%,95%,.8);
- border-color: hsla(210,15%,25%,.45) hsla(210,15%,25%,.5) hsla(210,15%,25%,.55);
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1),
- 0 0 3px hsla(210,15%,25%,.1);
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-}
-
-button:hover:active {
- background-color: hsla(210,15%,25%,.2);
- box-shadow: 0 1px 1px hsla(210,15%,25%,.2) inset,
- 0 0 2px hsla(210,15%,25%,.4) inset;
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 10ms;
- transition-timing-function: linear;
-}
diff --git a/browser/themes/linux/browser.css b/browser/themes/linux/browser.css
index 14b8692fd..74f942442 100644
--- a/browser/themes/linux/browser.css
+++ b/browser/themes/linux/browser.css
@@ -1519,70 +1519,6 @@ richlistitem[type~="action"][actiontype="switchtab"] > .ac-url-box > .ac-action-
list-style-image: url("chrome://browser/skin/Info.png");
}
-
-/* social share panel */
-
-.social-share-frame {
- background: linear-gradient(to bottom, rgba(242,242,242,.99), rgba(242,242,242,.95));
- border-left: 1px solid #f8f8f8;
- width: 330px;
- height: 150px;
- /* we resize our panels dynamically, make it look nice */
- transition: height 100ms ease-out, width 100ms ease-out;
-}
-
-#social-share-button {
- list-style-image: url("chrome://browser/skin/social/share-button.png");
-}
-
-#social-share-button[open],
-#social-share-button:hover:active {
- list-style-image: url("chrome://browser/skin/social/share-button-active.png");
-}
-
-.social-share-toolbar {
- border-right: 1px solid #dedede;
- background: linear-gradient(to bottom, rgba(247,247,247,.99), rgba(247,247,247,.95));
-}
-
-#social-share-provider-buttons {
- border-right: 1px solid #fbfbfb;
- padding: 6px;
-}
-
-#social-share-provider-buttons > .share-provider-button {
- padding: 6px;
- margin: 0;
- border: none;
- border-radius: 2px;
-}
-
-#social-share-provider-buttons > .share-provider-button[checked],
-#social-share-provider-buttons > .share-provider-button:active {
- padding: 5px;
- border: 1px solid #b5b5b8;
- box-shadow: inset 1px 1px 3px rgba(0, 0, 0, 0.2);
-}
-
-#social-share-provider-buttons > .share-provider-button[checked] {
- background: linear-gradient(to bottom, #d9d9d9, #e3e3e3);
-}
-
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-text {
- display: none;
-}
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-icon {
- width: 16px;
- min-height: 16px;
- max-height: 16px;
-}
-
-/* social recommending panel */
-
-#social-mark-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
/* Star button */
#star-button {
list-style-image: url("chrome://browser/skin/places/starPage.png");
@@ -2198,15 +2134,6 @@ toolbar[mode="text"] toolbarbutton.chevron > .toolbarbutton-icon {
}
%endif
-#social-provider-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-
-#social-provider-button > .toolbarbutton-menu-dropmarker {
- display: none;
-}
-
.toolbarbutton-badge-container {
margin: 5px 3px;
position: relative;
@@ -2236,89 +2163,6 @@ toolbar[iconsize="small"] .toolbarbutton-badge-container {
right: auto;
}
-.popup-notification-icon[popupid="servicesInstall"] {
- list-style-image: url(chrome://browser/skin/social/services-64.png);
-}
-#servicesInstall-notification-icon {
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-#social-undoactivation-button,
-#servicesInstall-learnmore-link {
- -moz-margin-start: 0; /* override default label margin to match description margin */
-}
-
-.social-activation-icon {
- width: auto;
- height: auto;
- max-height: 64px;
- max-width: 64px;
-}
-
-#social-activation-message {
- max-width: 250px;
-}
-
-#social-activation-message > label {
- margin: 0;
-}
-
-/* social toolbar provider menu */
-#social-statusarea-popup {
- margin-top: 0;
- margin-left: -12px;
- margin-right: -12px;
-}
-
-.social-statusarea-user {
- list-style-image:url("chrome://global/skin/icons/information-32.png");
-}
-
-.social-statusarea-user-portrait {
- width: 32px;
- height: 32px;
- border-radius: 2px;
- margin: 10px;
-}
-
-.social-panel > .panel-arrowcontainer > .panel-arrowcontent {
- padding: 0;
-}
-
-%include ../shared/social/chat.inc.css
-
-.chat-titlebar {
- background-color: #d9d9d9;
- background-image: linear-gradient(@toolbarHighlight@, rgba(255,255,255,0));
-}
-
-.chat-titlebar[selected] {
- background-color: #f0f0f0;
-}
-
-.chatbar-button {
- -moz-appearance: none;
- background-color: #d9d9d9;
- background-image: linear-gradient(@toolbarHighlight@, rgba(255,255,255,0));
-}
-
-.chatbar-button > .toolbarbutton-icon {
- -moz-margin-end: 0;
-}
-
-.chatbar-button:hover,
-.chatbar-button[open="true"] {
- background-color: #f0f0f0;
-}
-
-.chatbar-button[activity] {
- background-image: radial-gradient(circle farthest-corner at center 3px, rgb(233,242,252) 3%, rgba(172,206,255,0.75) 40%, rgba(87,151,201,0.5) 80%, rgba(87,151,201,0));
-}
-
-chatbox {
- border-top-left-radius: 2.5px;
- border-top-right-radius: 2.5px;
-}
-
#main-window[privatebrowsingmode=temporary] #TabsToolbar::before {
display: -moz-box;
content: "";
diff --git a/browser/themes/linux/jar.mn b/browser/themes/linux/jar.mn
index 45d62f9e8..b4e385633 100644
--- a/browser/themes/linux/jar.mn
+++ b/browser/themes/linux/jar.mn
@@ -13,7 +13,6 @@ browser.jar:
skin/classic/browser/aboutCertError_sectionCollapsed.png
skin/classic/browser/aboutCertError_sectionCollapsed-rtl.png
skin/classic/browser/aboutCertError_sectionExpanded.png
- skin/classic/browser/aboutSocialError.css
#ifdef MOZ_SERVICES_SYNC
skin/classic/browser/aboutSyncTabs.css
#endif
@@ -103,11 +102,6 @@ browser.jar:
* skin/classic/browser/preferences/preferences.css (preferences/preferences.css)
skin/classic/browser/preferences/applications.css (preferences/applications.css)
skin/classic/browser/preferences/aboutPermissions.css (preferences/aboutPermissions.css)
- skin/classic/browser/social/services-16.png (social/services-16.png)
- skin/classic/browser/social/services-64.png (social/services-64.png)
- skin/classic/browser/social/share-button.png (social/share-button.png)
- skin/classic/browser/social/share-button-active.png (social/share-button-active.png)
- skin/classic/browser/social/chat-icons.png (social/chat-icons.png)
skin/classic/browser/tabbrowser/alltabs.png (tabbrowser/alltabs.png)
skin/classic/browser/tabbrowser/connecting.png (tabbrowser/connecting.png)
skin/classic/browser/tabbrowser/loading.png (tabbrowser/loading.png)
diff --git a/browser/themes/linux/social/chat-icons.png b/browser/themes/linux/social/chat-icons.png
deleted file mode 100644
index cc895f93c..000000000
--- a/browser/themes/linux/social/chat-icons.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/linux/social/services-16.png b/browser/themes/linux/social/services-16.png
deleted file mode 100644
index 7001ea1f0..000000000
--- a/browser/themes/linux/social/services-16.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/linux/social/services-64.png b/browser/themes/linux/social/services-64.png
deleted file mode 100644
index e787bddc3..000000000
--- a/browser/themes/linux/social/services-64.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/linux/social/share-button-active.png b/browser/themes/linux/social/share-button-active.png
deleted file mode 100644
index 7df438db0..000000000
--- a/browser/themes/linux/social/share-button-active.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/linux/social/share-button.png b/browser/themes/linux/social/share-button.png
deleted file mode 100644
index c5298c143..000000000
--- a/browser/themes/linux/social/share-button.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/osx/aboutSocialError.css b/browser/themes/osx/aboutSocialError.css
deleted file mode 100644
index d1a9ad53c..000000000
--- a/browser/themes/osx/aboutSocialError.css
+++ /dev/null
@@ -1,98 +0,0 @@
-body {
- background-color: rgb(241, 244, 248);
- margin-top: 2em;
- font: message-box;
- font-size: 100%;
-}
-
-p {
- font-size: .8em;
-}
-
-#error-box {
- background: url('chrome://global/skin/icons/information-24.png') no-repeat left 4px;
- -moz-padding-start: 30px;
-}
-
-#error-box:-moz-locale-dir(rtl) {
- background-position: right 4px;
-}
-
-#main-error-msg {
- color: #4b4b4b;
- font-weight: bold;
-}
-
-
-#button-box {
- text-align: center;
- width: 75%;
- margin: 0 auto;
-}
-
-@media all and (min-width: 300px) {
- #error-box {
- max-width: 50%;
- margin: 0 auto;
- background-image: url('chrome://global/skin/icons/information-32.png');
- min-height: 36px;
- -moz-padding-start: 38px;
- }
-
- button {
- width: auto !important;
- min-width: 150px;
- }
-}
-
-@media all and (min-width: 780px) {
- #error-box {
- max-width: 30%;
- }
-}
-
-button {
- font: message-box;
- font-size: 0.6875em;
- -moz-appearance: none;
- -moz-user-select: none;
- width: 100%;
- margin: 2px 0;
- padding: 2px 6px;
- line-height: 1.2;
- background-color: hsla(210,30%,95%,.1);
- background-image: linear-gradient(hsla(0,0%,100%,.6), hsla(0,0%,100%,.1));
- background-clip: padding-box;
- border: 1px solid hsla(210,15%,25%,.4);
- border-color: hsla(210,15%,25%,.3) hsla(210,15%,25%,.35) hsla(210,15%,25%,.4);
- border-radius: 3px;
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1);
-
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-
-}
-
-button:hover {
- background-color: hsla(210,30%,95%,.8);
- border-color: hsla(210,15%,25%,.45) hsla(210,15%,25%,.5) hsla(210,15%,25%,.55);
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1),
- 0 0 3px hsla(210,15%,25%,.1);
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-}
-
-button:hover:active {
- background-color: hsla(210,15%,25%,.2);
- box-shadow: 0 1px 1px hsla(210,15%,25%,.2) inset,
- 0 0 2px hsla(210,15%,25%,.4) inset;
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 10ms;
- transition-timing-function: linear;
-}
diff --git a/browser/themes/osx/browser.css b/browser/themes/osx/browser.css
index f48c9b738..01b60260e 100644
--- a/browser/themes/osx/browser.css
+++ b/browser/themes/osx/browser.css
@@ -299,7 +299,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
-moz-box-pack: center;
}
-@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button):not(#social-provider-button) {
+@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button) {
padding-left: 5px;
padding-right: 5px;
}
@@ -341,7 +341,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
padding: 3px 7px;
}
-@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button):not(#social-provider-button) > .toolbarbutton-icon,
+@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button) > .toolbarbutton-icon,
@navbarLargeIcons@ .toolbarbutton-1[type=menu] > .toolbarbutton-text /* hack for add-ons that forcefully display the label */ {
-moz-padding-end: 17px;
}
@@ -358,18 +358,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
padding: 8px 5px 7px;
}
-@navbarLargeIcons@ #social-toolbar-item {
- margin-left: 2px;
- margin-right: 2px;
-}
-
-@navbarLargeIcons@ #social-toolbar-item > .toolbarbutton-1 {
- padding-left: 0;
- padding-right: 0;
-}
-
-@navbarLargeIcons@ .toolbarbutton-1:not(:hover):not(:active):not([open]) > .toolbarbutton-menubutton-dropmarker::before,
-@navbarLargeIcons@ #social-toolbar-item > .toolbarbutton-1:not(:hover):not(:active):not([open]) + .toolbarbutton-1:not(:hover):not(:active):not([open])::before {
+@navbarLargeIcons@ .toolbarbutton-1:not(:hover):not(:active):not([open]) > .toolbarbutton-menubutton-dropmarker::before {
content: "";
display: -moz-box;
width: 1px;
@@ -1205,118 +1194,6 @@ richlistitem[type~="action"][actiontype="switchtab"][selected="true"] > .ac-url-
}
-/* social share panel */
-
-#social-share-panel > iframe {
- background: linear-gradient(to bottom, #f0f4f7, #fafbfc);
- width: 300px;
- height: 150px;
-}
-
-#social-share-button {
- list-style-image: url(chrome://browser/skin/social/share-button.png);
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
-.social-share-toolbar {
- border-right: 1px solid #e2e5e8;
- background: linear-gradient(to bottom, #ffffff, #f5f7fa);
-}
-
-#social-share-provider-buttons {
- padding: 6px;
-}
-
-#social-share-provider-buttons > .share-provider-button {
- -moz-appearance: none;
- padding: 5px;
- margin: 1px;
- border: none;
- background: none;
- border-radius: 2px;
-}
-
-#social-share-provider-buttons > .share-provider-button[checked="true"]:not([disabled="true"]),
-#social-share-provider-buttons > .share-provider-button:hover,
-#social-share-provider-buttons > .share-provider-button:active {
- padding: 4px;
- border: 1px solid #aeb8c1;
- box-shadow: inset 1px 1px 1px rgba(10, 31, 51, 0.1);
-}
-
-#social-share-provider-buttons > .share-provider-button[checked="true"]:not([disabled="true"]) {
- background: linear-gradient(to bottom, rgba(230,232,234,.65), #d2d5d9);
-}
-
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-text {
- display: none;
-}
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-icon {
- width: 16px;
- min-height: 16px;
- max-height: 16px;
-}
-
-/* fixup corners for share panel */
-.social-panel > .social-panel-frame {
- border-radius: inherit;
-}
-
-#social-share-panel {
- max-height: 600px;
- min-height: 100px;
- max-width: 800px;
- min-width: 300px;
-}
-
-.social-share-frame {
- background: linear-gradient(to bottom, #f0f4f7, #fafbfc);
- width: 330px;
- height: 150px;
- /* we resize our panels dynamically, make it look nice */
- transition: height 100ms ease-out, width 100ms ease-out;
-}
-
-.social-share-frame:-moz-locale-dir(ltr) {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-.social-share-frame:-moz-locale-dir(rtl) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
-}
-
-#social-share-panel > .social-share-toolbar:-moz-locale-dir(ltr) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
-}
-
-#social-share-panel > .social-share-toolbar:-moz-locale-dir(rtl) {
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-#social-share-provider-buttons:-moz-locale-dir(ltr) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
-}
-
-#social-share-provider-buttons:-moz-locale-dir(rtl) {
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-/* social recommending panel */
-
-#social-mark-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
/* star button */
#star-button {
@@ -2435,17 +2312,6 @@ toolbarbutton.bookmark-item[dragover="true"][open="true"] {
}
%endif
-/* Social toolbar item */
-
-#social-provider-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-
-#social-provider-button > .toolbarbutton-menu-dropmarker {
- display: none;
-}
-
.toolbarbutton-badge-container {
margin: 0;
padding: 0;
@@ -2499,116 +2365,6 @@ toolbarbutton.bookmark-item[dragover="true"][open="true"] {
right: auto;
}
-.popup-notification-icon[popupid="servicesInstall"] {
- list-style-image: url(chrome://browser/skin/social/services-64.png);
-}
-#servicesInstall-notification-icon {
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-#social-undoactivation-button,
-#servicesInstall-learnmore-link {
- -moz-margin-start: 0; /* override default label margin to match description margin */
-}
-
-#socialActivatedNotification .popup-notification-button-container {
- margin-left: 6px;
-}
-
-.social-activation-icon {
- width: auto;
- height: auto;
- max-height: 64px;
- max-width: 64px;
-}
-
-#social-activation-message {
- max-width: 250px;
-}
-
-#social-activation-message > label {
- margin: 0;
-}
-
-/* social toolbar provider menu */
-.social-statusarea-popup {
- margin-top: 0;
- margin-left: -12px;
- margin-right: -12px;
-}
-
-.social-statusarea-user {
- -moz-appearance: none;
- border-bottom: 1px solid rgb(221,221,221);
- background-color: -moz-Dialog;
- position: relative;
- cursor: pointer;
- list-style-image:url("chrome://global/skin/icons/information-32.png");
-}
-
-.social-statusarea-user-portrait {
- width: 32px;
- height: 32px;
- border-radius: 2px;
- margin: 10px;
-}
-
-.social-statusarea-loggedInStatus {
- -moz-appearance: none;
- background: transparent;
- border: none;
- color: -moz-nativehyperlinktext;
- min-width: 0;
- margin: 0 6px;
- list-style-image: none;
-}
-
-.social-statusarea-user[_moz-menuactive] > vbox > .social-statusarea-loggedInStatus {
- text-decoration: underline;
-}
-
-.social-panel > .panel-arrowcontainer > .panel-arrowcontent {
- padding: 0;
-}
-
-.social-panel-frame {
- border-radius: inherit;
-}
-
-%include ../shared/social/chat.inc.css
-
-.chat-titlebar {
- background-color: #c4cfde;
- background-image: linear-gradient(rgba(255,255,255,.5), rgba(255,255,255,0));
-}
-
-.chat-titlebar[selected] {
- background-color: #dae3f0;
-}
-
-.chatbar-button {
- -moz-appearance: none;
- background-color: #c4cfde;
- background-image: linear-gradient(rgba(255,255,255,.5), rgba(255,255,255,0));
-}
-
-.chatbar-button > .toolbarbutton-icon {
- -moz-margin-end: 0;
-}
-
-.chatbar-button:hover,
-.chatbar-button[open="true"] {
- background-color: #dae3f0;
-}
-
-.chatbar-button[activity]:not([open="true"]) {
- background-image: radial-gradient(circle farthest-corner at center 3px, rgb(255,255,255) 3%, rgba(186,221,251,0.75) 40%, rgba(127,179,255,0.5) 80%, rgba(127,179,255,0.25));
-}
-
-chatbox {
- border-top-left-radius: 2.5px;
- border-top-right-radius: 2.5px;
-}
-
#main-window[privatebrowsingmode=temporary] #toolbar-menubar {
background-image: url("chrome://browser/skin/privatebrowsing-dark.png");
background-position: top right;
diff --git a/browser/themes/osx/jar.mn b/browser/themes/osx/jar.mn
index 0ab3fb39c..865ad5989 100644
--- a/browser/themes/osx/jar.mn
+++ b/browser/themes/osx/jar.mn
@@ -12,7 +12,6 @@ browser.jar:
skin/classic/browser/aboutCertError_sectionCollapsed.png
skin/classic/browser/aboutCertError_sectionCollapsed-rtl.png
skin/classic/browser/aboutCertError_sectionExpanded.png
- skin/classic/browser/aboutSocialError.css
#ifdef MOZ_SERVICES_SYNC
skin/classic/browser/aboutSyncTabs.css
#endif
@@ -126,11 +125,6 @@ browser.jar:
* skin/classic/browser/preferences/preferences.css (preferences/preferences.css)
skin/classic/browser/preferences/applications.css (preferences/applications.css)
skin/classic/browser/preferences/aboutPermissions.css (preferences/aboutPermissions.css)
- skin/classic/browser/social/services-16.png (social/services-16.png)
- skin/classic/browser/social/services-64.png (social/services-64.png)
- skin/classic/browser/social/share-button.png (social/share-button.png)
- skin/classic/browser/social/share-button-active.png (social/share-button-active.png)
- skin/classic/browser/social/chat-icons.png (social/chat-icons.png)
skin/classic/browser/tabbrowser/alltabs.png (tabbrowser/alltabs.png)
skin/classic/browser/tabbrowser/alltabs-inverted.png (tabbrowser/alltabs-inverted.png)
skin/classic/browser/tabbrowser/newtab.png (tabbrowser/newtab.png)
diff --git a/browser/themes/osx/social/chat-icons.png b/browser/themes/osx/social/chat-icons.png
deleted file mode 100644
index cc895f93c..000000000
--- a/browser/themes/osx/social/chat-icons.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/osx/social/services-16.png b/browser/themes/osx/social/services-16.png
deleted file mode 100644
index 7001ea1f0..000000000
--- a/browser/themes/osx/social/services-16.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/osx/social/services-64.png b/browser/themes/osx/social/services-64.png
deleted file mode 100644
index e787bddc3..000000000
--- a/browser/themes/osx/social/services-64.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/osx/social/share-button-active.png b/browser/themes/osx/social/share-button-active.png
deleted file mode 100644
index e819a740b..000000000
--- a/browser/themes/osx/social/share-button-active.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/osx/social/share-button.png b/browser/themes/osx/social/share-button.png
deleted file mode 100644
index 931874dc3..000000000
--- a/browser/themes/osx/social/share-button.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/shared/social/chat.inc.css b/browser/themes/shared/social/chat.inc.css
deleted file mode 100644
index 62a95bea8..000000000
--- a/browser/themes/shared/social/chat.inc.css
+++ /dev/null
@@ -1,239 +0,0 @@
-%if 0
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-%endif
-
-.chat-status-icon {
- max-height: 16px;
- max-width: 16px;
- padding: 0;
-}
-
-.chat-toolbarbutton {
- -moz-appearance: none;
- border: none;
- padding: 0;
- margin: 0;
- background: none;
- width: 16px;
-}
-
-.chat-toolbarbutton > .toolbarbutton-text {
- display: none;
-}
-
-.chat-toolbarbutton > .toolbarbutton-icon {
- width: inherit;
-}
-
-.chat-close-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons.png');
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
-.chat-close-button:hover {
- -moz-image-region: rect(0, 32px, 16px, 16px);
-}
-
-.chat-close-button:hover:active {
- -moz-image-region: rect(0, 48px, 16px, 32px);
-}
-
-.chat-minimize-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons.png');
- -moz-image-region: rect(16px, 16px, 32px, 0);
-}
-
-.chat-minimize-button:hover {
- -moz-image-region: rect(16px, 32px, 32px, 16px);
-}
-
-.chat-minimize-button:hover:active {
- -moz-image-region: rect(16px, 48px, 32px, 32px);
-}
-
-.chat-swap-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons.png');
- -moz-image-region: rect(48px, 16px, 64px, 0);
-}
-
-.chat-swap-button:hover {
- -moz-image-region: rect(48px, 32px, 64px, 16px);
-}
-
-.chat-swap-button:hover:active {
- -moz-image-region: rect(48px, 48px, 64px, 32px);
-}
-
-chatbar > chatbox > .chat-titlebar > .chat-swap-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons.png');
- -moz-image-region: rect(32px, 16px, 48px, 0);
-}
-
-chatbar > chatbox > .chat-titlebar > .chat-swap-button:hover {
- -moz-image-region: rect(32px, 32px, 48px, 16px);
-}
-
-chatbar > chatbox > .chat-titlebar > .chat-swap-button:hover:active {
- -moz-image-region: rect(32px, 48px, 48px, 32px);
-}
-
-@media (min-resolution: 2dppx) {
- .chat-close-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons@2x.png');
- -moz-image-region: rect(0, 32px, 32px, 0);
- }
-
- .chat-close-button:hover {
- -moz-image-region: rect(0, 64px, 32px, 32px);
- }
-
- .chat-close-button:hover:active {
- -moz-image-region: rect(0, 96px, 32px, 64px);
- }
-
- .chat-minimize-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons@2x.png');
- -moz-image-region: rect(32px, 32px, 64px, 0);
- }
-
- .chat-minimize-button:hover {
- -moz-image-region: rect(32px, 64px, 64px, 32px);
- }
-
- .chat-minimize-button:hover:active {
- -moz-image-region: rect(32px, 96px, 64px, 64px);
- }
-
- .chat-swap-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons@2x.png');
- -moz-image-region: rect(96px, 32px, 128px, 0);
- }
-
- .chat-swap-button:hover {
- -moz-image-region: rect(96px, 64px, 128px, 32px);
- }
-
- .chat-swap-button:hover:active {
- -moz-image-region: rect(96px, 96px, 128px, 64px);
- }
-
- chatbar > chatbox > .chat-titlebar > .chat-swap-button {
- list-style-image: url('chrome://browser/skin/social/chat-icons@2x.png');
- -moz-image-region: rect(64px, 32px, 96px, 0);
- }
-
- chatbar > chatbox > .chat-titlebar > .chat-swap-button:hover {
- -moz-image-region: rect(64px, 64px, 96px, 32px);
- }
-
- chatbar > chatbox > .chat-titlebar > .chat-swap-button:hover:active {
- -moz-image-region: rect(64px, 96px, 96px, 64px);
- }
-}
-
-.chat-title {
- font-weight: bold;
- color: black;
- text-shadow: none;
- cursor: inherit;
-}
-
-.chat-titlebar {
- height: 20px;
- min-height: 20px;
- width: 100%;
- margin: 0;
- padding: 2px;
- -moz-padding-start: 6px;
- border: none;
- border-bottom: 1px solid #ccc;
- cursor: pointer;
-}
-
-.chat-titlebar > .notification-anchor-icon {
- margin-left: 2px;
- margin-right: 2px;
-}
-
-.chat-titlebar[minimized="true"] {
- border-bottom: none;
-}
-
-.chat-titlebar[activity] {
- background-image: radial-gradient(ellipse closest-side at center, rgb(255,255,255), rgba(255,255,255,0));
- background-repeat: no-repeat;
- background-size: 100% 20px;
- background-position: 0 -10px;
-}
-
-.chat-frame {
- padding: 0;
- margin: 0;
- overflow: hidden;
-}
-
-.chatbar-button {
- list-style-image: url("chrome://browser/skin/social/services-16.png");
- margin: 0;
- padding: 2px;
- height: 21px;
- width: 21px;
- border: 1px solid #ccc;
- border-bottom: none;
-}
-
-@media (min-resolution: 2dppx) {
- .chatbar-button {
- list-style-image: url("chrome://browser/skin/social/services-16@2x.png");
- }
-}
-
-.chatbar-button > .toolbarbutton-icon {
- width: 16px;
-}
-
-.chatbar-button > menupopup > .menuitem-iconic > .menu-iconic-left > .menu-iconic-icon {
- width: auto;
- height: auto;
- max-height: 16px;
- max-width: 16px;
-}
-
-.chatbar-button[open="true"] {
- box-shadow: inset 0 2px 5px rgba(0,0,0,0.6), 0 1px rgba(255,255,255,0.2);
-}
-
-.chatbar-button > .toolbarbutton-text,
-.chatbar-button > .toolbarbutton-menu-dropmarker {
- display: none;
-}
-
-.chatbar-button > menupopup > menuitem[activity] {
- font-weight: bold;
-}
-
-.chatbar-innerbox {
- background: transparent;
- margin: -285px 0 0;
- overflow: hidden;
-}
-
-chatbar {
- -moz-margin-end: 20px;
-}
-
-chatbox {
- -moz-margin-start: 4px;
- background-color: white;
- border: 1px solid #ccc;
- border-bottom: none;
-}
-
-window > chatbox {
- -moz-margin-start: 0px;
- margin: 0px;
- border: none;
- padding: 0px;
-}
diff --git a/browser/themes/windows/aboutSocialError.css b/browser/themes/windows/aboutSocialError.css
deleted file mode 100644
index d1a9ad53c..000000000
--- a/browser/themes/windows/aboutSocialError.css
+++ /dev/null
@@ -1,98 +0,0 @@
-body {
- background-color: rgb(241, 244, 248);
- margin-top: 2em;
- font: message-box;
- font-size: 100%;
-}
-
-p {
- font-size: .8em;
-}
-
-#error-box {
- background: url('chrome://global/skin/icons/information-24.png') no-repeat left 4px;
- -moz-padding-start: 30px;
-}
-
-#error-box:-moz-locale-dir(rtl) {
- background-position: right 4px;
-}
-
-#main-error-msg {
- color: #4b4b4b;
- font-weight: bold;
-}
-
-
-#button-box {
- text-align: center;
- width: 75%;
- margin: 0 auto;
-}
-
-@media all and (min-width: 300px) {
- #error-box {
- max-width: 50%;
- margin: 0 auto;
- background-image: url('chrome://global/skin/icons/information-32.png');
- min-height: 36px;
- -moz-padding-start: 38px;
- }
-
- button {
- width: auto !important;
- min-width: 150px;
- }
-}
-
-@media all and (min-width: 780px) {
- #error-box {
- max-width: 30%;
- }
-}
-
-button {
- font: message-box;
- font-size: 0.6875em;
- -moz-appearance: none;
- -moz-user-select: none;
- width: 100%;
- margin: 2px 0;
- padding: 2px 6px;
- line-height: 1.2;
- background-color: hsla(210,30%,95%,.1);
- background-image: linear-gradient(hsla(0,0%,100%,.6), hsla(0,0%,100%,.1));
- background-clip: padding-box;
- border: 1px solid hsla(210,15%,25%,.4);
- border-color: hsla(210,15%,25%,.3) hsla(210,15%,25%,.35) hsla(210,15%,25%,.4);
- border-radius: 3px;
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1);
-
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-
-}
-
-button:hover {
- background-color: hsla(210,30%,95%,.8);
- border-color: hsla(210,15%,25%,.45) hsla(210,15%,25%,.5) hsla(210,15%,25%,.55);
- box-shadow: 0 1px 0 hsla(0,0%,100%,.3) inset,
- 0 0 0 1px hsla(0,0%,100%,.3) inset,
- 0 1px 0 hsla(0,0%,100%,.1),
- 0 0 3px hsla(210,15%,25%,.1);
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 150ms;
- transition-timing-function: ease;
-}
-
-button:hover:active {
- background-color: hsla(210,15%,25%,.2);
- box-shadow: 0 1px 1px hsla(210,15%,25%,.2) inset,
- 0 0 2px hsla(210,15%,25%,.4) inset;
- transition-property: background-color, border-color, box-shadow;
- transition-duration: 10ms;
- transition-timing-function: linear;
-}
diff --git a/browser/themes/windows/browser.css b/browser/themes/windows/browser.css
index 4e3dcbea0..516984e0f 100644
--- a/browser/themes/windows/browser.css
+++ b/browser/themes/windows/browser.css
@@ -790,7 +790,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
-moz-box-pack: center;
}
-@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button):not(#social-provider-button) {
+@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button) {
padding-left: 5px;
padding-right: 5px;
}
@@ -832,7 +832,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
padding: 3px 7px;
}
-@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button):not(#social-provider-button) > .toolbarbutton-icon,
+@navbarLargeIcons@ .toolbarbutton-1[type=menu]:not(#back-button):not(#forward-button):not(#feed-button) > .toolbarbutton-icon,
@navbarLargeIcons@ .toolbarbutton-1[type=menu] > .toolbarbutton-text /* hack for add-ons that forcefully display the label */ {
-moz-padding-end: 17px;
}
@@ -849,18 +849,7 @@ toolbar[mode=full] .toolbarbutton-1 > .toolbarbutton-menubutton-button {
padding: 8px 5px 7px;
}
-@navbarLargeIcons@ #social-toolbar-item {
- margin-left: 2px;
- margin-right: 2px;
-}
-
-@navbarLargeIcons@ #social-toolbar-item > .toolbarbutton-1 {
- padding-left: 0;
- padding-right: 0;
-}
-
-@navbarLargeIcons@ .toolbarbutton-1:not(:hover):not(:active):not([open]) > .toolbarbutton-menubutton-dropmarker::before,
-@navbarLargeIcons@ #social-toolbar-item > .toolbarbutton-1:not(:hover):not(:active):not([open]) + .toolbarbutton-1:not(:hover):not(:active):not([open])::before {
+@navbarLargeIcons@ .toolbarbutton-1:not(:hover):not(:active):not([open]) > .toolbarbutton-menubutton-dropmarker::before {
content: "";
display: -moz-box;
width: 1px;
@@ -1748,119 +1737,6 @@ richlistitem[type~="action"][actiontype="switchtab"] > .ac-url-box > .ac-action-
-moz-image-region: rect(0, 48px, 16px, 32px);
}
-
-/* social share panel */
-
-#social-share-panel > iframe {
- background: linear-gradient(to bottom, #f0f4f7, #fafbfc);
- width: 300px;
- height: 150px;
-}
-
-#social-share-button {
- list-style-image: url(chrome://browser/skin/social/share-button.png);
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
-.social-share-toolbar {
- border-right: 1px solid #e2e5e8;
- background: linear-gradient(to bottom, #ffffff, #f5f7fa);
-}
-
-#social-share-provider-buttons {
- padding: 6px;
-}
-
-#social-share-provider-buttons > .share-provider-button {
- -moz-appearance: none;
- padding: 5px;
- margin: 1px;
- border: none;
- background: none;
- border-radius: 2px;
-}
-
-#social-share-provider-buttons > .share-provider-button[checked="true"]:not([disabled="true"]),
-#social-share-provider-buttons > .share-provider-button:hover,
-#social-share-provider-buttons > .share-provider-button:active {
- padding: 4px;
- border: 1px solid #aeb8c1;
- box-shadow: inset 1px 1px 1px rgba(10, 31, 51, 0.1);
-}
-
-#social-share-provider-buttons > .share-provider-button[checked="true"]:not([disabled="true"]) {
- background: linear-gradient(to bottom, rgba(230,232,234,.65), #d2d5d9);
-}
-
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-text {
- display: none;
-}
-#social-share-provider-buttons > .share-provider-button > .toolbarbutton-icon {
- width: 16px;
- min-height: 16px;
- max-height: 16px;
-}
-
-/* fixup corners for share panel */
-.social-panel > .social-panel-frame {
- border-radius: inherit;
-}
-
-#social-share-panel {
- max-height: 600px;
- min-height: 100px;
- max-width: 800px;
- min-width: 300px;
-}
-
-.social-share-frame {
- background: linear-gradient(to bottom, #f0f4f7, #fafbfc);
- width: 330px;
- height: 150px;
- /* we resize our panels dynamically, make it look nice */
- transition: height 100ms ease-out, width 100ms ease-out;
-}
-
-.social-share-frame:-moz-locale-dir(ltr) {
- border-top-left-radius: 0;
- border-bottom-left-radius: 0;
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-.social-share-frame:-moz-locale-dir(rtl) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
- border-top-right-radius: 0;
- border-bottom-right-radius: 0;
-}
-
-#social-share-panel > .social-share-toolbar:-moz-locale-dir(ltr) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
-}
-
-#social-share-panel > .social-share-toolbar:-moz-locale-dir(rtl) {
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-#social-share-provider-buttons:-moz-locale-dir(ltr) {
- border-top-left-radius: inherit;
- border-bottom-left-radius: inherit;
-}
-
-#social-share-provider-buttons:-moz-locale-dir(rtl) {
- border-top-right-radius: inherit;
- border-bottom-right-radius: inherit;
-}
-
-/* social recommending panel */
-
-#social-mark-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
-}
-
/* star button */
#star-button {
@@ -3000,17 +2876,6 @@ toolbarbutton.bookmark-item[dragover="true"][open="true"] {
}
%endif
-/* Social toolbar item */
-
-#social-provider-button {
- -moz-image-region: rect(0, 16px, 16px, 0);
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-
-#social-provider-button > .toolbarbutton-menu-dropmarker {
- display: none;
-}
-
.toolbarbutton-badge-container {
margin: 0;
padding: 0;
@@ -3064,116 +2929,6 @@ toolbarbutton.bookmark-item[dragover="true"][open="true"] {
right: auto;
}
-.popup-notification-icon[popupid="servicesInstall"] {
- list-style-image: url(chrome://browser/skin/social/services-64.png);
-}
-#servicesInstall-notification-icon {
- list-style-image: url(chrome://browser/skin/social/services-16.png);
-}
-#social-undoactivation-button,
-#servicesInstall-learnmore-link {
- -moz-margin-start: 0; /* override default label margin to match description margin */
-}
-
-#socialActivatedNotification .popup-notification-button-container {
- margin-left: 6px;
-}
-
-.social-activation-icon {
- width: auto;
- height: auto;
- max-height: 64px;
- max-width: 64px;
-}
-
-#social-activation-message {
- max-width: 250px;
-}
-
-#social-activation-message > label {
- margin: 0;
-}
-
-/* social toolbar provider menu */
-.social-statusarea-popup {
- margin-top: 0;
- margin-left: -12px;
- margin-right: -12px;
-}
-
-.social-statusarea-user {
- -moz-appearance: none;
- border-bottom: 1px solid rgb(221,221,221);
- background-color: -moz-Dialog;
- position: relative;
- cursor: pointer;
- list-style-image:url("chrome://global/skin/icons/information-32.png");
-}
-
-.social-statusarea-user-portrait {
- width: 32px;
- height: 32px;
- border-radius: 2px;
- margin: 10px;
-}
-
-.social-statusarea-loggedInStatus {
- -moz-appearance: none;
- background: transparent;
- border: none;
- color: -moz-nativehyperlinktext;
- min-width: 0;
- margin: 0 6px;
- list-style-image: none;
-}
-
-.social-statusarea-user[_moz-menuactive] > vbox > .social-statusarea-loggedInStatus {
- text-decoration: underline;
-}
-
-.social-panel > .panel-arrowcontainer > .panel-arrowcontent {
- padding: 0;
-}
-
-.social-panel-frame {
- border-radius: inherit;
-}
-
-%include ../shared/social/chat.inc.css
-
-.chat-titlebar {
- background-color: #c4cfde;
- background-image: linear-gradient(rgba(255,255,255,.5), rgba(255,255,255,0));
-}
-
-.chat-titlebar[selected] {
- background-color: #dae3f0;
-}
-
-.chatbar-button {
- -moz-appearance: none;
- background-color: #c4cfde;
- background-image: linear-gradient(rgba(255,255,255,.5), rgba(255,255,255,0));
-}
-
-.chatbar-button > .toolbarbutton-icon {
- -moz-margin-end: 0;
-}
-
-.chatbar-button:hover,
-.chatbar-button[open="true"] {
- background-color: #dae3f0;
-}
-
-.chatbar-button[activity]:not([open="true"]) {
- background-image: radial-gradient(circle farthest-corner at center 3px, rgb(255,255,255) 3%, rgba(186,221,251,0.75) 40%, rgba(127,179,255,0.5) 80%, rgba(127,179,255,0.25));
-}
-
-chatbox {
- border-top-left-radius: 2.5px;
- border-top-right-radius: 2.5px;
-}
-
#main-window[privatebrowsingmode=temporary] #toolbar-menubar {
background-image: url("chrome://browser/skin/privatebrowsing-dark.png");
background-position: top right;
diff --git a/browser/themes/windows/jar.mn b/browser/themes/windows/jar.mn
index fbe169d6a..a6aafc27b 100644
--- a/browser/themes/windows/jar.mn
+++ b/browser/themes/windows/jar.mn
@@ -15,7 +15,6 @@ browser.jar:
skin/classic/browser/aboutCertError_sectionCollapsed.png
skin/classic/browser/aboutCertError_sectionCollapsed-rtl.png
skin/classic/browser/aboutCertError_sectionExpanded.png
- skin/classic/browser/aboutSocialError.css
#ifdef MOZ_SERVICES_SYNC
skin/classic/browser/aboutSyncTabs.css
#endif
@@ -126,11 +125,6 @@ browser.jar:
* skin/classic/browser/preferences/preferences.css (preferences/preferences.css)
skin/classic/browser/preferences/applications.css (preferences/applications.css)
skin/classic/browser/preferences/aboutPermissions.css (preferences/aboutPermissions.css)
- skin/classic/browser/social/services-16.png (social/services-16.png)
- skin/classic/browser/social/services-64.png (social/services-64.png)
- skin/classic/browser/social/share-button.png (social/share-button.png)
- skin/classic/browser/social/share-button-active.png (social/share-button-active.png)
- skin/classic/browser/social/chat-icons.png (social/chat-icons.png)
skin/classic/browser/tabbrowser/alltabs.png (tabbrowser/alltabs.png)
skin/classic/browser/tabbrowser/alltabs-inverted.png (tabbrowser/alltabs-inverted.png)
skin/classic/browser/tabbrowser/newtab.png (tabbrowser/newtab.png)
@@ -266,7 +260,6 @@ browser.jar:
skin/classic/aero/browser/aboutCertError_sectionCollapsed.png
skin/classic/aero/browser/aboutCertError_sectionCollapsed-rtl.png
skin/classic/aero/browser/aboutCertError_sectionExpanded.png
- skin/classic/aero/browser/aboutSocialError.css
#ifdef MOZ_SERVICES_SYNC
skin/classic/aero/browser/aboutSyncTabs.css
#endif
@@ -378,11 +371,6 @@ browser.jar:
* skin/classic/aero/browser/preferences/preferences.css (preferences/preferences.css)
skin/classic/aero/browser/preferences/applications.css (preferences/applications.css)
skin/classic/aero/browser/preferences/aboutPermissions.css (preferences/aboutPermissions.css)
- skin/classic/aero/browser/social/services-16.png (social/services-16.png)
- skin/classic/aero/browser/social/services-64.png (social/services-64.png)
- skin/classic/aero/browser/social/share-button.png (social/share-button.png)
- skin/classic/aero/browser/social/share-button-active.png (social/share-button-active.png)
- skin/classic/aero/browser/social/chat-icons.png (social/chat-icons.png)
skin/classic/aero/browser/tabbrowser/alltabs.png (tabbrowser/alltabs.png)
skin/classic/aero/browser/tabbrowser/alltabs-inverted.png (tabbrowser/alltabs-inverted.png)
skin/classic/aero/browser/tabbrowser/newtab.png (tabbrowser/newtab.png)
diff --git a/browser/themes/windows/social/chat-icons.png b/browser/themes/windows/social/chat-icons.png
deleted file mode 100644
index cc895f93c..000000000
--- a/browser/themes/windows/social/chat-icons.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/windows/social/services-16.png b/browser/themes/windows/social/services-16.png
deleted file mode 100644
index 7001ea1f0..000000000
--- a/browser/themes/windows/social/services-16.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/windows/social/services-64.png b/browser/themes/windows/social/services-64.png
deleted file mode 100644
index e787bddc3..000000000
--- a/browser/themes/windows/social/services-64.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/windows/social/share-button-active.png b/browser/themes/windows/social/share-button-active.png
deleted file mode 100644
index e819a740b..000000000
--- a/browser/themes/windows/social/share-button-active.png
+++ /dev/null
Binary files differ
diff --git a/browser/themes/windows/social/share-button.png b/browser/themes/windows/social/share-button.png
deleted file mode 100644
index 931874dc3..000000000
--- a/browser/themes/windows/social/share-button.png
+++ /dev/null
Binary files differ