Chrome extension: Isolate pageAction logic
Remove pageAction logic from extension router, and put it in a separate file. The pageAction URL parsing logic has been simplified, and all pageAction-related files have been moved to a separate directory.
This commit is contained in:
parent
4834f1c289
commit
1055350425
@ -56,39 +56,6 @@ limitations under the License.
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {string} url URL of PDF Viewer.
|
|
||||||
* @return {string|undefined} The percent-encoded URL of the (PDF) file.
|
|
||||||
*/
|
|
||||||
function parseViewerURL(url) {
|
|
||||||
if (url.lastIndexOf(VIEWER_URL, 0) !== 0) {
|
|
||||||
// Does not even start with the correct URL. Bye!
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
url = url.match(/[&?]file=([^&#]+)/);
|
|
||||||
if (url) {
|
|
||||||
url = url[1];
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {number} tabId ID of tab where the page action will be shown
|
|
||||||
* @param {string} url URL to be displayed in page action
|
|
||||||
*/
|
|
||||||
function showPageAction(tabId, displayUrl) {
|
|
||||||
var url = parseExtensionURL(displayUrl) || parseViewerURL(displayUrl);
|
|
||||||
if (url) {
|
|
||||||
chrome.pageAction.setPopup({
|
|
||||||
tabId: tabId,
|
|
||||||
popup: 'pageActionPopup.html?file=' + url
|
|
||||||
});
|
|
||||||
chrome.pageAction.show(tabId);
|
|
||||||
} else {
|
|
||||||
console.log('Unable to get PDF url from ' + displayUrl);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO(rob): Use declarativeWebRequest once declared URL-encoding is
|
// TODO(rob): Use declarativeWebRequest once declared URL-encoding is
|
||||||
// supported, see http://crbug.com/273589
|
// supported, see http://crbug.com/273589
|
||||||
// (or rewrite the query string parser in viewer.js to get it to
|
// (or rewrite the query string parser in viewer.js to get it to
|
||||||
@ -114,12 +81,6 @@ limitations under the License.
|
|||||||
})
|
})
|
||||||
}, ['blocking']);
|
}, ['blocking']);
|
||||||
|
|
||||||
chrome.runtime.onMessage.addListener(function(message, sender) {
|
|
||||||
if (message === 'showPageAction' && sender.tab) {
|
|
||||||
showPageAction(sender.tab.id, sender.tab.url);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// When session restore is used, viewer pages may be loaded before the
|
// When session restore is used, viewer pages may be loaded before the
|
||||||
// webRequest event listener is attached (= page not found).
|
// webRequest event listener is attached (= page not found).
|
||||||
// Reload these tabs.
|
// Reload these tabs.
|
||||||
|
48
extensions/chromium/pageAction/background.js
Normal file
48
extensions/chromium/pageAction/background.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
||||||
|
/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */
|
||||||
|
/*
|
||||||
|
Copyright 2014 Mozilla Foundation
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
/* globals chrome */
|
||||||
|
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
(function PageActionClosure() {
|
||||||
|
/**
|
||||||
|
* @param {number} tabId - ID of tab where the page action will be shown.
|
||||||
|
* @param {string} url - URL to be displayed in page action.
|
||||||
|
*/
|
||||||
|
function showPageAction(tabId, displayUrl) {
|
||||||
|
// rewriteUrlClosure in viewer.js ensures that the URL looks like
|
||||||
|
// chrome-extension://[extensionid]/http://example.com/file.pdf
|
||||||
|
var url = /^chrome-extension:\/\/[a-p]{32}\/([^#]+)/.exec(displayUrl);
|
||||||
|
if (url) {
|
||||||
|
url = url[1];
|
||||||
|
chrome.pageAction.setPopup({
|
||||||
|
tabId: tabId,
|
||||||
|
popup: '/pageAction/popup.html?file=' + encodeURIComponent(url)
|
||||||
|
});
|
||||||
|
chrome.pageAction.show(tabId);
|
||||||
|
} else {
|
||||||
|
console.log('Unable to get PDF url from ' + displayUrl);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
chrome.runtime.onMessage.addListener(function(message, sender) {
|
||||||
|
if (message === 'showPageAction' && sender.tab) {
|
||||||
|
showPageAction(sender.tab.id, sender.tab.url);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})();
|
@ -39,6 +39,6 @@ body {
|
|||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
<body contentEditable="plaintext-only" spellcheck="false">
|
<body contentEditable="plaintext-only" spellcheck="false">
|
||||||
<script src="pageActionPopup.js"></script>
|
<script src="popup.js"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
@ -20,3 +20,4 @@ limitations under the License.
|
|||||||
<script src="extension-router.js"></script>
|
<script src="extension-router.js"></script>
|
||||||
<script src="pdfHandler-v2.js"></script>
|
<script src="pdfHandler-v2.js"></script>
|
||||||
<script src="pdfHandler-vcros.js"></script>
|
<script src="pdfHandler-vcros.js"></script>
|
||||||
|
<script src="pageAction/background.js"></script>
|
||||||
|
1
make.js
1
make.js
@ -879,6 +879,7 @@ target.chromium = function() {
|
|||||||
'extensions/chromium/*.css',
|
'extensions/chromium/*.css',
|
||||||
'extensions/chromium/icon*.png',],
|
'extensions/chromium/icon*.png',],
|
||||||
CHROME_BUILD_DIR],
|
CHROME_BUILD_DIR],
|
||||||
|
['extensions/chromium/pageAction/*.*', CHROME_BUILD_DIR + '/pageAction'],
|
||||||
['external/webL10n/l10n.js', CHROME_BUILD_CONTENT_DIR + '/web'],
|
['external/webL10n/l10n.js', CHROME_BUILD_CONTENT_DIR + '/web'],
|
||||||
['web/viewer.css', CHROME_BUILD_CONTENT_DIR + '/web'],
|
['web/viewer.css', CHROME_BUILD_CONTENT_DIR + '/web'],
|
||||||
['external/bcmaps/*', CHROME_BUILD_CONTENT_DIR + '/web/cmaps'],
|
['external/bcmaps/*', CHROME_BUILD_CONTENT_DIR + '/web/cmaps'],
|
||||||
|
Loading…
Reference in New Issue
Block a user