summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authorrginda@chromium.org <rginda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-07 22:53:01 +0000
committerrginda@chromium.org <rginda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-07 22:53:01 +0000
commitb7fe05014e57b5859aad0749a0d5002e53831a16 (patch)
tree9cf968dd2246c13a951355ce128b52b380f69cd8 /chrome/browser
parent0150cfcb238a357ce4daaa9d9c6d5a4516f9a8eb (diff)
downloadchromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.zip
chromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.tar.gz
chromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.tar.bz2
Make file manager work better as a component extension
This CL contains some changes necessary to make the file manager work better as a component extension (rather than just in the test harness.) file_manager_dialogs.cc: turn off context menu file_manager.css: add opacity transition, comments file_manager.css: encode images as data: urls file_manager.js: embed preview images, close window, fix path calculation file_manager_dialogs.cc: allow closing, hide title BUG=none TEST=manual Review URL: http://codereview.chromium.org/6816029 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@80861 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/resources/file_manager/css/file_manager.css11
-rw-r--r--chrome/browser/resources/file_manager/js/file_manager.js57
-rw-r--r--chrome/browser/ui/views/file_manager_dialogs.cc3
3 files changed, 57 insertions, 14 deletions
diff --git a/chrome/browser/resources/file_manager/css/file_manager.css b/chrome/browser/resources/file_manager/css/file_manager.css
index cacdce2..a80e51f 100644
--- a/chrome/browser/resources/file_manager/css/file_manager.css
+++ b/chrome/browser/resources/file_manager/css/file_manager.css
@@ -8,10 +8,12 @@
body {
-webkit-box-flex: 1;
-webkit-box-orient: vertical;
+ -webkit-transition: opacity 0.07s linear;
-webkit-user-select: none;
display: -webkit-box;
height: 100%;
margin: 0;
+ opacity: 0;
padding: 0;
position: absolute;
width: 100%;
@@ -154,7 +156,8 @@ body {
/* The icon in the name column. */
.detail-icon {
-webkit-margin-end: 3px;
- background-image: url(../images/icon-unknown.png);
+ /* ../images/icon-unknown.png */
+ background-image: url();
background-position: center;
background-repeat: no-repeat;
height: 24px;
@@ -163,7 +166,8 @@ body {
/* Icon for image files. */
.detail-icon[iconType="image"] {
- background-image: url(../images/icon-image.png);
+ /* ../images/icon-image.png */
+ background-image: url();
}
/* The filename text in the preview pane. */
@@ -195,7 +199,8 @@ body {
/* Checkboard background to distinguish images with alpha channels. */
.preview-img.transparent-background {
- background-image: url(../images/preview-background.png);
+ /* ../images/preview-background.png */
+ background-image: url();
}
/* The selection summary text at the bottom of the preview pane. */
diff --git a/chrome/browser/resources/file_manager/js/file_manager.js b/chrome/browser/resources/file_manager/js/file_manager.js
index 0171631..2407d40 100644
--- a/chrome/browser/resources/file_manager/js/file_manager.js
+++ b/chrome/browser/resources/file_manager/js/file_manager.js
@@ -41,9 +41,13 @@ function FileManager(dialogDom, filesystem, params) {
this.initDom_();
this.initDialogType_();
- this.changeDirectory('/');
+ // TODO(rginda): Fix this when we've got the root dir sorted out.
+ // http://code.google.com/p/chromium-os/issues/detail?id=13845
+ this.changeDirectory('/tmp');
this.summarizeSelection_();
this.updatePreview_();
+
+ this.table.querySelector('.list').focus();
}
FileManager.prototype = {
@@ -56,11 +60,6 @@ FileManager.prototype = {
// Private variables and helper functions.
/**
- * Directory where we can find icons.
- */
- const ICON_PATH = 'images/';
-
- /**
* Unicode codepoint for 'BLACK RIGHT-POINTING SMALL TRIANGLE'.
*/
const RIGHT_TRIANGLE = '\u25b8';
@@ -88,6 +87,26 @@ FileManager.prototype = {
};
/**
+ * Canned preview images for non-image files.
+ *
+ * When we're built as a component extension we won't be able to access urls
+ * that haven't been explicitly packed into the resource bundle. It's
+ * simpler to pack them here as data: urls than it is to maintain code that
+ * maps urls into the resource bundle. Please make sure to check any new
+ * source images, and refer to the file in the comment here.
+ *
+ * Pro Tip: On *nix, the base64 command line tool can be used to base64
+ * encode arbitrary files.
+ */
+ const previewArt = {
+ // ../images/preview-unknown.png
+ 'unknown': '',
+
+ // ../images/preview-folder.png
+ 'folder': '',
+ };
+
+ /**
* Return a translated string.
*
* Wrapper function to make dealing with translated strings more concise.
@@ -125,8 +144,8 @@ FileManager.prototype = {
if (entry.isDirectory)
return 'folder';
- for (var name in this.iconTypes) {
- var value = this.iconTypes[name];
+ for (var name in iconTypes) {
+ var value = iconTypes[name];
if (value instanceof RegExp) {
if (value.test(entry.name))
@@ -332,6 +351,8 @@ FileManager.prototype = {
'dblclick', this.onDetailDoubleClick_.bind(this));
this.table.selectionModel.addEventListener(
'change', this.onDetailSelectionChanged_.bind(this));
+
+ this.dialogDom_.style.opacity = '1';
};
/**
@@ -600,9 +621,10 @@ FileManager.prototype = {
var iconType = getIconType(entry);
if (iconType != 'image') {
// Not an image, display a canned clip-art graphic.
- this.previewImage_.src = ICON_PATH + 'preview-' + iconType + '.png';
+ this.previewImage_.src = previewArt[iconType];
} else {
// File is an image, fetch the thumbnail.
+
var fileManager = this;
batchAsyncCall(entry, 'file', function(file) {
@@ -725,6 +747,9 @@ FileManager.prototype = {
if (entry.isDirectory)
return this.changeDirectory(entry.fullPath);
+ if (!this.okButton_.disabled)
+ this.onOk_();
+
};
/**
@@ -738,11 +763,19 @@ FileManager.prototype = {
function onReadSome(entries) {
if (entries.length == 0)
- return;
+ return;
// Splice takes the to-be-spliced-in array as individual parameters,
// rather than as an array, so we need to perform some acrobatics...
var spliceArgs = [].slice.call(entries);
+
+ // Hide files that start with a dot ('.').
+ // TODO(rginda): User should be able to override this. Support for other
+ // commonly hidden patterns might be nice too.
+ spliceArgs = spliceArgs.filter(function(e) {
+ return e.name.substr(0, 1) != '.';
+ });
+
spliceArgs.unshift(0, 0); // index, deleteCount
self.table.dataModel.splice.apply(self.table.dataModel, spliceArgs);
@@ -787,6 +820,7 @@ FileManager.prototype = {
*/
FileManager.prototype.onCancel_ = function(event) {
chrome.fileBrowserPrivate.cancelDialog();
+ window.close();
};
/**
@@ -807,6 +841,7 @@ FileManager.prototype = {
chrome.fileBrowserPrivate.selectFile(this.currentDirEntry_.fullPath +
'/' + filename, 0);
+ window.close();
return;
}
@@ -832,6 +867,7 @@ FileManager.prototype = {
// Multi-file selection has no other restrictions.
if (this.dialogType_ == FileManager.DialogType.SELECT_OPEN_FILES) {
chrome.fileBrowserPrivate.selectFiles(ary);
+ window.close();
return;
}
@@ -848,6 +884,7 @@ FileManager.prototype = {
}
chrome.fileBrowserPrivate.selectFile(ary[0], 0);
+ window.close();
};
})();
diff --git a/chrome/browser/ui/views/file_manager_dialogs.cc b/chrome/browser/ui/views/file_manager_dialogs.cc
index 062bcc1..98b2952 100644
--- a/chrome/browser/ui/views/file_manager_dialogs.cc
+++ b/chrome/browser/ui/views/file_manager_dialogs.cc
@@ -118,12 +118,13 @@ class FileManagerDialog
// windows.close() and you've allowed that. If the output parameter
// is set to true, then the dialog is closed. The default is false.
virtual void OnCloseContents(TabContents* source, bool* out_close_dialog) {
+ *out_close_dialog = true;
}
// A callback to allow the delegate to dictate that the window should not
// have a title bar. This is useful when presenting branded interfaces.
virtual bool ShouldShowDialogTitle() const {
- return true;
+ return false;
}
// A callback to allow the delegate to inhibit context menu or show